zoukankan      html  css  js  c++  java
  • RabbitMQ基础组件和SpringBoot整合RabbitMQ简单示例

    交换器(Exchange)

    交换器就像路由器,我们先是把消息发到交换器,然后交换器再根据绑定键(binding key)和生产者发送消息时的路由键routingKey,

    按照交换类型Exchange Type(fanoutdirecttopic)把消息投递到对应的队列。(明白这个概念很重要,后面的代码里面充分体现了这一点)。

    RabbitMQ基础知识可查看消息队列RabbitMQ基础知识详解

    队列(Queue)

    存放消息的队列。

    绑定(Binding)

    交换器怎么知道把这条消息投递到哪个队列呢?这就需要用到绑定了。大概就是:使用某个绑定键(binding key),把某个队列(Queue)绑定到某个交换器(Exchange),这样交换器就知道根据路由键把这条消息投递到哪个队列了。(后面的代码里面充分体现了这一点)

    加入 RabbitMQ maven 依赖

    RabbitMQ实战(一)Spring Boot 整合 RabbitMQ

     

    配置

    application.yaml文件中配置

    RabbitMQ实战(一)Spring Boot 整合 RabbitMQ

     

    RabbitMQConfig.java 配置

    @Configuration

    public class RabbitMQConfig {

    public final static String QUEUE_NAME = "spring-boot-queue";

    public final static String EXCHANGE_NAME = "spring-boot-exchange";

    public final static String BINDING_KEY = "spring.boot.key.#";

    // 创建队列

    @Bean

    public Queue queue() {

    return new Queue(QUEUE_NAME);

    }

    // 创建一个 topic 类型的交换器

    @Bean

    public TopicExchange exchange() {

    return new TopicExchange(EXCHANGE_NAME);

    }

    // 使用路由键(routingKey)把队列(Queue)绑定到交换器(Exchange)

    @Bean

    public Binding binding(Queue queue, TopicExchange exchange) {

    return BindingBuilder.bind(queue).to(exchange).with(BINDING_KEY);

    }

    }

    注:上面配置的是TopicExchange

    实际业务中,可以配置多个队列和binding来满足需求。

    生产者

    直接调用 rabbitTemplate 的 convertAndSend 方法就可以了。从下面的代码里也可以看出,我们不是把消息直接发送到队列里面的,而是先发送到了交换器,交换器再根据路由键把我们的消息投递到对应的队列。

    @RestController

    public class ProducerController {

    @Autowired

    private RabbitTemplate rabbitTemplate;

    @GetMapping("/sendMessage")

    public String sendMessage() {

    new Thread(() -> {

    for (int i = 0; i < 100; i++) {

    String value = new DateTime().toString("yyyy-MM-dd HH:mm:ss");

    Console.log("send message {}", value);

    rabbitTemplate.convertAndSend(RabbitMQConfig.EXCHANGE_NAME, RabbitMQConfig.ROUTING_KEY, value);

    }

    }).start();

    return "ok";

    }

    }

    消费者

    消费者也很简单,只需要对应的方法上加入 @RabbitListener 注解,指定需要监听的队列名称即可。

    RabbitMQ实战(一)Spring Boot 整合 RabbitMQ

     

    运行项目

    运行项目,然后打开浏览器,输入 http://localhost:9999/sendMessage(具体地址根据服务器)。在控制台就可以看到生产者在不停的的发送消息,消费者不断的在消费消息。

    RabbitMQ实战(一)Spring Boot 整合 RabbitMQ

     

    控制台

    打开 RabbitMQ web 控制台,也可以看到刚才我们在代码里面配置的交换器和队列,以及绑定信息。

    RabbitMQ实战(一)Spring Boot 整合 RabbitMQ

     

    查看交换器的详情

    RabbitMQ实战(一)Spring Boot 整合 RabbitMQ

     

    查看队列

    RabbitMQ实战(一)Spring Boot 整合 RabbitMQ
     
  • 相关阅读:
    马哥学习笔记二十一——LVS DR模型
    马哥学习笔记二十——集群系列之LVS调度方法及NAT模型
    CCNA学习笔记九——访问控制列表(ACL)
    CCNA学习笔记八——动态路由协议
    CCNA学习笔记七——路由概述
    CCNA学习笔记六——网络层协议
    WPF点补间、拟合回归直线
    WPF三种基本触发器与【与或】逻辑触发器
    C#与mysql做ASP.NET网页数据库查询速度测试
    VS2013单元测试及代码覆盖率分析--Xunit
  • 原文地址:https://www.cnblogs.com/nizuimeiabc1/p/9397876.html
Copyright © 2011-2022 走看看