RabbitMQ深度探索:SpringBoot 整合 RabbitMQ

需创建复合项目
父工程 Maven 依赖:
XML 复制代码
<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.0.0.RELEASE</version>
  </parent>


<!--  父工程要打成 pom 包-->
  <groupId>com.qcby</groupId>
  <artifactId>springboot-rabbitmq</artifactId>
  <packaging>pom</packaging>
  <modules>
    <module>producer</module>
    <module>sms-consumer</module>
  </modules>
  <version>1.0-SNAPSHOT</version>

  <dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>3.8.1</version>
      <scope>test</scope>
    </dependency>

    <!-- springboot-web组件 -->
    <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <!-- 添加springboot对amqp的支持 -->
    <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-amqp</artifactId>
    </dependency>
    <dependency>
      <groupId>org.apache.commons</groupId>
      <artifactId>commons-lang3</artifactId>
    </dependency>
    <!--fastjson -->
    <dependency>
      <groupId>com.alibaba</groupId>
      <artifactId>fastjson</artifactId>
      <version>1.2.49</version>
    </dependency>

    <dependency>
      <groupId>org.projectlombok</groupId>
      <artifactId>lombok</artifactId>
    </dependency>

  </dependencies>
生产者工程代码:
  1. 配置类:

    java 复制代码
    package com.qcby.config;
    
    import org.springframework.amqp.core.Binding;
    import org.springframework.amqp.core.BindingBuilder;
    import org.springframework.amqp.core.FanoutExchange;
    import org.springframework.amqp.core.Queue;
    import org.springframework.context.annotation.Bean;
    import org.springframework.stereotype.Component;
    
    
    @Component
    public class RabbitMQConfig {
    
        //定义交换机
        private String EXCHANGE_SPRINGBOOT_NAME = "boyatop_ex";
    
        //定义短信队列
        private String FANOUT_SMS_QUEUE = "fanout_sms_queue";
    
        //定义邮件队列
        private String FANOUT_EMAIL_QUEUE = "fanout_email_queue";
    
        //配置邮件队列
        @Bean
        public Queue emailQueue(){
            return new Queue(FANOUT_EMAIL_QUEUE);
        }
    
        //配置消息队列
        @Bean
        public Queue smsQueue(){
            return new Queue(FANOUT_SMS_QUEUE);
        }
    
        //配置交换机
        @Bean
        public FanoutExchange fanoutExchange(){
            return new FanoutExchange(EXCHANGE_SPRINGBOOT_NAME);
        }
    
        //将队列绑定交换机
        @Bean
        public Binding bindingSmsFanoutExchange(Queue smsQueue,FanoutExchange fanoutExchange){
            return BindingBuilder.bind(smsQueue).to(fanoutExchange);
        }
    
        @Bean
        public Binding bindingEmailFanoutExchange(Queue emailQueue,FanoutExchange fanoutExchange){
            return BindingBuilder.bind(emailQueue).to(fanoutExchange);
        }
    }
  2. 消息实体类:

    java 复制代码
    package com.qcby.entity;
    
    import lombok.AllArgsConstructor;
    import lombok.Data;
    import lombok.NoArgsConstructor;
    
    import java.io.Serializable;
    
    @Data
    @AllArgsConstructor
    @NoArgsConstructor
    public class MsgEntity implements Serializable {
        private String MsgId;
        private String UserId;
        private String phone;
        private String email;
    }
  3. 生产者代码:

    java 复制代码
    package com.qcby.controller;
    
    import com.qcby.entity.MsgEntity;
    import org.springframework.amqp.core.AmqpTemplate;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.web.bind.annotation.RequestMapping;
    import org.springframework.web.bind.annotation.RestController;
    
    import java.util.UUID;
    
    @RestController
    public class FanoutProducer {
        @Autowired
        private AmqpTemplate amqpTemplate;
    
        /**
         * 发送消息
         *
         * @return
         */
        @RequestMapping("/sendMsg")
        public String sendMsg() {
            /**
             * 1.交换机名称
             * 2.路由key名称
             * 3.发送内容
             */
            MsgEntity msgEntity = new MsgEntity(UUID.randomUUID().toString(),"22","12345","edddd");
            amqpTemplate.convertAndSend("boyatop_ex", "", msgEntity);
            return "success";
        }
    }
  4. yml 文件:

    java 复制代码
    spring:
      rabbitmq:
        ####连接地址
        host: 127.0.0.1
        ####端口号
        port: 5672
        ####账号
        username: guest
        ####密码
        password: guest
        ### 地址
        virtual-host: boyatopVirtualHost
消费者工程代码:
  1. 实体类:

    java 复制代码
    package com.qcby.entity;
    
    import lombok.AllArgsConstructor;
    import lombok.Data;
    import lombok.NoArgsConstructor;
    
    import java.io.Serializable;
    
    @Data
    @AllArgsConstructor
    @NoArgsConstructor
    public class MsgEntity implements Serializable {
        private String MsgId;
        private String UserId;
        private String phone;
        private String email;
    }
  2. 监听队列:

    java 复制代码
    package com.qcby.controller;
    
    import com.qcby.entity.MsgEntity;
    import lombok.extern.slf4j.Slf4j;
    import org.springframework.amqp.rabbit.annotation.RabbitHandler;
    import org.springframework.amqp.rabbit.annotation.RabbitListener;
    import org.springframework.stereotype.Component;
    
    @Slf4j
    @Component
    @RabbitListener(queues = "fanout_sms_queue")
    public class smsController {
    
        @RabbitHandler
        public void listen(MsgEntity msgEntity){
            log.info("email:" + msgEntity);
            System.out.println(msgEntity);
        }
    }
  3. yml 文件:

    java 复制代码
    spring:
      rabbitmq:
        ####连接地址
        host: 127.0.0.1
        ####端口号
        port: 5672
        ####账号
        username: guest
        ####密码
        password: guest
        ### 地址
        virtual-host: boyatopVirtualHost
    server:
      port: 8081

生产者如何获取消费结果:

根据业务来定:
  1. 消费者消费成功结果:能够在数据库中插入一条数据
Roketmq 自带全局消息 id,能够根据该全局消息获取消费结果
  1. 异步返回一个全局 id,前端使用 ajax 定时主动查询
  2. 在roketmq 中,自带根据消息 id 查询是否消费成功
原理:
  1. 生产者投递消息 MQ 服务器,NQ 服务器端在这时候返回一个全局消息 id ,当消费者消费该消息之后,消费者会给我们 MQ 服务器发送通知,标识该消息消费成功
  2. 生产者获取到该消息全局 id,每隔 2s 时间调用 MQ 服务器接口查询是否有被消费成功
相关推荐
直奔標竿1 小时前
Java开发者AI转型第二十五课!Spring AI 个人知识库实战(四)——RAG来源追溯落地,拒绝AI幻觉
java·开发语言·人工智能·spring boot·后端·spring
敖正炀2 小时前
WebFlux 深度:Reactor 线程模型、背压与错误处理
spring boot
BING_Algorithm2 小时前
一文搞定 AOP 所有核心知识点
spring boot·后端·spring
勿忘初心12213 小时前
【Java实战】SpringBoot 集成 freemarker 导出 Word 模板
java·spring boot·freemarker·模板引擎·word导出·后端实战
绿草在线3 小时前
SpringBoot项目实战:从零搭建高效开发环境
java·spring boot·后端
空中海5 小时前
Spring Boot Kafka 项目 Demo:订单事件系统 专家知识、源码阅读路线与面试题
spring boot·kafka·linq
默 语1 天前
基于 Spring Boot 3 + LangChain4j 快速构建企业级 AI 应用实战
人工智能·spring boot·后端
Dontla1 天前
aio-pika介绍(基于asyncio的Python异步消息队列客户端,用于操作RabbitMQ,并实现对AMQP协议支持)
python·rabbitmq·ruby
薪火铺子1 天前
SpringBoot WebServer启动与监听器原理深度解析
spring boot·后端·tomcat
KmSH8umpK1 天前
SpringBoot 分布式锁实战:从单机锁到Redis分布式锁全覆盖,解决超卖、重复下单、幂等并发问题
spring boot·redis·分布式