代码编织梦想

一:Ubuntu安装RocketMQ

Ubuntu 安装 Rocketmq_羁客%的博客-CSDN博客

二:添加RocketMQ依赖

<!--rocket mq 依赖-->
<dependency>
    <groupId>org.apache.rocketmq</groupId>
    <artifactId>rocketmq-spring-boot-starter</artifactId>
    <version>2.1.1</version>
    <exclusions>
        <exclusion>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
        </exclusion>
        <exclusion>
            <groupId>org.springframework</groupId>
            <artifactId>spring-core</artifactId>
        </exclusion>
        <exclusion>
            <groupId>org.springframework</groupId>
            <artifactId>spring-webmvc</artifactId>
        </exclusion>
    </exclusions>
</dependency>

三:在application中添加RocketMQ配置

#rocketmq 配置
rocketmq:
  name-server: 127.0.0.0:9876 #IP根据自己电脑服务器配置的 mqbroker->brokerIP1 修改一下,最好不要使用这个
  producer:
    group: rocketmq_group

myrocketmq-config:
  my-topic: rocketmq_topic
  my-consumer-group: rocketmq_group_consumer

四:编写消费者,消息生产者,消息实体类(自定义)

//Rocket消费者(Push 推送型消费者,被动型消费)
@Slf4j
@Component
@RocketMQMessageListener(consumerGroup = "${myrocketmq-config.my-consumer-group}", topic = "${myrocketmq-config.my-topic}")
public class RocketConsumer implements RocketMQListener<RocketmqVo> {

    @Override
    public void onMessage(RocketmqVo rocketmqVo) {
        log.info("收到RocketMQ消息:{}",rocketmqVo);
    }
}
//Rocket生产者
@Slf4j
@Component
public class RocketProduce {

    @Value("${myrocketmq-config.my-topic}")
    private String mqTopic;
    @Value("${myrocketmq-config.my-consumer-group}")
    private String mqConsumerGroup;
    @Autowired
    private RocketMQTemplate mqTemplate;

    /**
     * 同步发送
     *
     * @param title 发送消息
     * @param data  消息内容
     */
    public void sync(String title, Object data) {
        String time = new SimpleDateFormat("yyyyMMdd HH:mm:ss").format(new Date());
        RocketmqVo rocketmqVo = new RocketmqVo(mqConsumerGroup, mqTopic, title, time, data);
        SendResult sendResult = mqTemplate.syncSend(mqTopic, rocketmqVo);
        log.info("同步发送:{}", rocketmqVo);
        log.info("同步发送消息结果:{}", sendResult);
    }

    /**
     * 异步发送
     *
     * @param title 发送消息
     * @param data  消息内容
     */
    public void async(String title, Object data) {
        String time = new SimpleDateFormat("yyyyMMdd HH:mm:ss").format(new Date());
        RocketmqVo rocketmqVo = new RocketmqVo(mqConsumerGroup, mqTopic, title, time, data);
        log.info("异步发送:{}", rocketmqVo);
        mqTemplate.asyncSend(mqTopic, rocketmqVo, new SendCallback() {
            @Override
            public void onSuccess(SendResult var1) {
                log.info("异步发送成功:{}", var1);
            }

            @Override
            public void onException(Throwable var1) {
                log.info("异步发送失败:{}", var1.getMessage());
            }
        });
    }

    /**
     * 单向发送
     *
     * @param title 发送消息
     */
    public void oneway(String title, Object data) {
        String time = new SimpleDateFormat("yyyyMMdd HH:mm:ss").format(new Date());
        RocketmqVo rocketmqVo = new RocketmqVo(mqConsumerGroup, mqTopic, title, time, data);
        mqTemplate.sendOneWay(mqTopic, rocketmqVo);
        log.info("单向发送:{}", rocketmqVo);
    }
}
//Rocket消息实体
@Data
@AllArgsConstructor
@NoArgsConstructor
@ToString
public class RocketmqVo {

    @Value("${myrocketmq-config.my-consumer-group}")
    private String group;

    @Value("${myrocketmq-config.my-topic}")
    private String topic;

    private String title;

    private String date;

    private Object data;


    public RocketmqVo(String title, String date, Object data) {
        this.title = title;
        this.date = date;
        this.data = data;
    }
}

五:测试Controller

@RestController
@RequestMapping("/mqtest")
public class RocketController {

    @Resource
    private RocketProduce producer;

    @RequestMapping("/sendMessageSync/{msg}")
    public String sendMessageSync(@PathVariable("msg") String message) {
        producer.sync(message, null);
        return "消息发送完成";
    }

    @RequestMapping("/sendMessageAsync/{msg}")
    public String sendMessageAsync(@PathVariable("msg") String message) {
        producer.async(message, null);
        return "消息发送完成";
    }

    @RequestMapping("/sendMessageOneway/{msg}")
    public String sendMessageOneway(@PathVariable("msg") String message) {
        producer.oneway(message, null);
        return "消息发送完成";
    }
}

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/qq_37778018/article/details/126300098

个人笔记 rocketmq学习-爱代码爱编程

pom.xml文件 <dependency> <groupId>com.alibaba.rocketmq</groupId> <artifactId>rocketmq-client</artifactId> <version>3.2.6<

RocketMQ学习1-3:SpringBoot整合RocketMQ 和 消费者获取消息实现消费-爱代码爱编程

项目目录结构 pom 依赖 <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId>

springboot 整合rocketmq-爱代码爱编程

centos7安装rocketmq 在rocketmq官网下载压缩包 官网地址:https://www.apache.org/dyn/closer.cgi?path=rocketmq/4.7.1/rocketmq-all-4.7.1-bin-release.zip 下载到本地后上传至centos7,我的上传路径为/usr/rocektmq ,然后解压

SpringBoot整合 RocketMQ-爱代码爱编程

SpringBoot整合 RocketMQ 前言一、引入maven二、修改配置文件三、创建生产者工具类四、创建消费者五、创建Controller六、查看结果 前言 springboot版本为2.2.2.RELEASERocketMQ版本为4.5.1RocketMQ Docker版安装https://blog.csdn.net/qq_43548

springboot整合RocketMQ-爱代码爱编程

1.配置pom.xml <properties> <java.version>1.8</java.version> <rocketmq-stater.version>2.2.1</rocketmq-stater.version> <rocke

springBoot整合rocketMq-爱代码爱编程

springBoot整合rocketMq 因写了一个rocketMQ 发送,有一个消息发送一次,进行一下producer创建,后修改为项目启动创建生产者。 一、项目结构 二、maven相关包: <!-- https://mvnrepository.com/artifact/com.alibaba.rocketmq/rocketmq-cli

springboot整合rocketmq实战_itzhongzi的博客-爱代码爱编程

pom配置 <?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schema

48. 从零开始学springboot: 接入rocketmq_cto技术的博客-爱代码爱编程

前言 微服务的架构越来越流行, 很多老旧项目面临着解耦重构, 复杂项目的解耦通常会引入一些中间件来帮助我们更好的完成工作, 本章, 我们就来通过实例了解下消息中间件的用法. 市面上比较流行的消息中间件如下 因为鱼哥的

ubuntu 安装 rocketmq_羁客%的博客-爱代码爱编程

1.下载(在下面地址选择自己需要的版本的rocketmq) http://rocketmq.apache.org/release_notes/ 2.解压,更改配置   将下载的zip文件解压到自己需要安装的位置   在unbuntu系统下需要修改安装跟目录下的两个文件   bin/runserver.sh  和  bin/runbroker.sh 

kafka,activemq,rabbitmq,rocketmq都有什么区别?_橘子ꦿ.๓的博客-爱代码爱编程

对于吞吐量来说kafka和rocketmq支持高吞吐,activemq和rabbitmq比他们低一个数量级。对于延迟量来说rabbitmq是最低的 1.从社区活跃度 按照目前网络上的资料,rabbitmq、activemq、zeromq三者中,综合来看,rabbitmq是首选 2.持久化消息比较 activemq和rabbitmq都支持。持久化消息