Spring Boot整合RocketMQ

  1. pom.xml导入RocketMQ依赖

    <dependency>
        <groupId>org.apache.rocketmq</groupId>
        <artifactId>rocketmq-spring-boot-starter</artifactId>
        <version>2.2.2</version>
    </dependency>
    
  2. application.yml中添加配置

    rocketmq:
        name-server: 127.0.0.1:9876
        producer:
            group: x
            access-key: myaccesskey
            secret-key: mysecretKey
            send-message-timeout: 10000
            tls-enable: true
        consumer:
            group: x
            access-key: myaccesskey
            secret-key: mysecretKey
            tls-enable: true
    
  3. 创建MQ工具类

    public class MqUtil {
    
        private final RocketMQTemplate rocketMQTemplate;
    
        public MqUtil(RocketMQTemplate rocketMQTemplate) {
            this.rocketMQTemplate = rocketMQTemplate;
        }
    
        /**
         * 单条通知发送
         *
         * @param topic   主题
         * @param message 消息
         */
        public void convertAndSend(String topic, Object message) {
            rocketMQTemplate.convertAndSend(topic, message);
        }
    
        /**
         * 批量通知发送
         *
         * @param topic    主题
         * @param messages 消息集合
         */
        public <T extends Message<?>> SendResult syncSend(String topic, Collection<T> messages) {
            return rocketMQTemplate.syncSend(topic, messages);
        }
    
        /**
         * 批量通知发送
         *
         * @param topic        主题
         * @param messages     消息集合
         * @param sendCallback 回调函数
         */
        public <T extends Message<?>> void asyncSend(String topic, Collection<T> messages, SendCallback sendCallback) {
            rocketMQTemplate.asyncSend(topic, messages, sendCallback);
        }
    }
    
  4. 注入工具类Bean

    @Bean
    public MqUtil mqUtil(RocketMQTemplate rocketMQTemplate) {
      return new MqUtil(rocketMQTemplate);
    }
    
  5. 测试发消息

    @Resource
    private MqUtil mqUtil;
    
    @Test
    public void test() {
      mqUtil.convertAndSend(TopicConstant.TOPIC_B, "123456");
    }
    
  6. 订阅接收消息

    @Slf4j
    @Service
    @RequiredArgsConstructor(onConstructor = @__({@Autowired}))
    @RocketMQMessageListener(consumerGroup = GroupConstant.GROUP_A, topic = TopicConstant.TOPIC_B)
    public class TopicAConsumer implements RocketMQListener<Message> {
    
        @Override
        public void onMessage(Message message) {
            log.info(JsonUtil.toJsonStr(message));
        }
    }
    
相关推荐
编程重生之路28 分钟前
Springboot启动异常 错误: 找不到或无法加载主类 xxx.Application异常
java·spring boot·后端
politeboy38 分钟前
k8s启动springboot容器的时候,显示找不到application.yml文件
java·spring boot·kubernetes
世间万物皆对象7 小时前
Spring Boot核心概念:日志管理
java·spring boot·单元测试
懒洋洋大魔王8 小时前
RocketMQ的使⽤
java·rocketmq·java-rocketmq
qq_17448285759 小时前
springboot基于微信小程序的旧衣回收系统的设计与实现
spring boot·后端·微信小程序
代码小鑫11 小时前
A043-基于Spring Boot的秒杀系统设计与实现
java·开发语言·数据库·spring boot·后端·spring·毕业设计
真心喜欢你吖11 小时前
SpringBoot与MongoDB深度整合及应用案例
java·spring boot·后端·mongodb·spring
周全全11 小时前
Spring Boot + Vue 基于 RSA 的用户身份认证加密机制实现
java·vue.js·spring boot·安全·php
飞升不如收破烂~12 小时前
Spring boot常用注解和作用
java·spring boot·后端
计算机毕设源码qq-383653104112 小时前
(附项目源码)Java开发语言,215 springboot 大学生爱心互助代购网站,计算机毕设程序开发+文案(LW+PPT)
java·开发语言·spring boot·mysql·课程设计