Springboot整合RabbitMq,消息队列搞起来

安装rabbitMq

//拉取镜像
docker pull rabbitmq:management
//运行成容器
docker run -dit --name Myrabbitmq -e RABBITMQ_DEFAULT_USER=admin -e RABBITMQ_DEFAULT_PASS=admin -p 15672:15672 -p 5672:5672 rabbitmq:management
  • 官网 https://hub.docker.com/_/rabbitmq
  • :management – 带界面的
  • 用户名admin密码admin

rabbitMq基本概念

基本模型

消息
消息
消息
生产者
交换机
队列
消费者
  • 消息加入队列前要经过交换机,3种最常见的交换机类型

Direct Exchange(直连交换机)

消息a
消息a
消息a
消息b
消息b
消息b
生产者1
交换机1
队列1
消费者1
消费者2
  • 多个绑定的消费者轮流消费消息,每人每次消费一个,不重复消费

Fanout Exchange(群发交换机)

消息a
消息a
消息a
消息b
消息b
消息b
消息b
消息a
生产者1
交换机1
队列1
消费者1
消费者2
  • 所有绑定的消费者消费全部消息,等同群发

Topic Exchange (主题交换机)

男性话题消息
男性话题消息
男性话题消息
女性话题消息
女性话题消息
女性话题消息
生产者1
交换机1
队列1
消费者1
生产者2
队列2
消费者2
  • 按主题来订阅消费,可以使用* #来模糊订阅
  • * (星号) 用来表示一个单词 (必须出现的)
  • # (井号) 用来表示任意数量(零个或多个)单词
  • topicA.* 代表topicA开头的所有单字母话题,如topicA.C
  • topicA.# 代表topicA开头的所有话题,如topicA.ABC

创建三种类型的springboot+rabbitMq项目

在这里插入图片描述
在这里插入图片描述

  • rabbitMq网页界面默认端口15672
  • rabbitMq通信端口5672
  • 生产者端口8021
  • 消费者端口8022

springboot编码直连交换机

准备

  • 生产者/消费者pom.xml
<dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-amqp</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.amqp</groupId>
            <artifactId>spring-rabbit-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>
  • 生产者application.yml
#a-rabbitmq-provider
server:
  port: 8021
spring:
  #项目名字
  application:
    name: rabbitmq-provider
  #配置rabbitMq 服务器
  rabbitmq:
    host: 127.0.0.1
    port: 5672
    username: admin
    password: admin
  • 生产者直连交换机配置
/**
 * direct exchange
 **/
@Configuration
public class DirectRabbitConfig {
    //队列名:TestDirectQueue
    @Bean
    public Queue TestDirectQueue() {
        // durable:是否持久化,默认是false,持久化队列:会被存储在磁盘上,当消息代理重启时仍然存在,暂存队列:当前连接有效
        // exclusive:默认也是false,只能被当前创建的连接使用,而且当连接关闭后队列即被删除。此参考优先级高于durable
        // autoDelete:是否自动删除,当没有生产者或者消费者使用此队列,该队列会自动删除。
        //   return new Queue("TestDirectQueue",true,true,false);

        //一般设置一下队列的持久化就好,其余两个就是默认false
        return new Queue("TestDirectQueue",true);
    }

    //Direct交换机 起名:TestDirectExchange
    @Bean
    DirectExchange TestDirectExchange() {
        return new DirectExchange("TestDirectExchange",true,false);
    }

    //绑定  将队列和交换机绑定, 并设置用于匹配键:TestDirectRouting
    @Bean
    Binding bindingDirect() {
        return BindingBuilder.bind(TestDirectQueue()).to(TestDirectExchange()).with("TestDirectRouting");
    }
}
  • 生产者对外api接口,用于测试
import org.springframework.amqp.rabbit.core.RabbitTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;
import java.util.HashMap;
import java.util.Map;
import java.util.UUID;
 
/**
 * 测试API
 **/
@RestController
public class SendMessageController {
    @Autowired
    RabbitTemplate rabbitTemplate;  //使用RabbitTemplate,这提供了接收/发送等等方法
    @GetMapping("/sendDirectMessage")
    public String sendDirectMessage() {
        String messageId = String.valueOf(UUID.randomUUID());
        String messageData = "test message, hello!";
        String createTime = LocalDateTime.now().format(DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"));
        Map<String,Object> map=new HashMap<>();
        map.put("messageId",messageId);
        map.put("messageData",messageData);
        map.put("createTime",createTime);
        //将消息携带绑定键值:TestDirectRouting 发送到交换机TestDirectExchange
        rabbitTemplate.convertAndSend("TestDirectExchange", "TestDirectRouting", map);
        return "发送了消息::"+map.toString();
    }
}
  • 测试

在这里插入图片描述

  • 消息发送成功
    在这里插入图片描述

  • rabbitMq队列里面出现一个消息,且未被消费

编写直连交换机消费者,去消费消息
  • 消费者pom.xml同生产者
  • 消费者application.yml
server:
  port: 8022
spring:
  #给项目来个名字
  application:
    name: rabbitmq-consumer
  #配置rabbitMq 服务器
  rabbitmq:
    host: 127.0.0.1
    port: 5672
    username: root
    password: root
  • 消费者配置类DirectRabbitConfig.java

/**
 * 消费者配置类可以省略,但配置后消费者也可以发消息
 **/
@Configuration
public class DirectRabbitConfig {
 
    //队列名:TestDirectQueue
    @Bean
    public Queue TestDirectQueue() {
        return new Queue("TestDirectQueue",true);
    }
 
    //Direct交换机 起名:TestDirectExchange
    @Bean
    DirectExchange TestDirectExchange() {
        return new DirectExchange("TestDirectExchange");
    }
 
    //绑定  将队列和交换机绑定, 并设置用于匹配键:TestDirectRouting
    @Bean
    Binding bindingDirect() {
        return BindingBuilder.bind(TestDirectQueue()).to(TestDirectExchange()).with("TestDirectRouting");
    }
}
  • 消费者监听类DirectReceiver.java
/**
 * direct exchange 消费者接受消息
 */
@Component
@RabbitListener(queues = "TestDirectQueue")//监听的队列名称 TestDirectQueue
public class DirectReceiver {

    @RabbitHandler
    public void process(Map testMessage) {
        System.out.println("DirectReceiver消费者收到消息  : " + testMessage.toString());
    }

}
  • 启动消费者项目,控制台输出消费消息
主题交换机、群发交换机、消息确认代码直接看源码

项目源码

https://gitee.com/cschina/springboot-rabbitmq

参考与感谢

https://blog.youkuaiyun.com/qq_35387940/article/details/100514134

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值