RabbitMQ实战(一)Spring Boot 整合 RabbitMQ

本文主要介绍RabbitMQ基础组件和SpringBoot整合RabbitMQ简单示例java

交换器(Exchange)

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

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

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

队列(Queue)

存放消息的队列。app

绑定(Binding)

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

加入 RabbitMQ maven 依赖

RabbitMQ实战(一)Spring Boot 整合 RabbitMQ

 

配置

application.yaml文件中配置spring-boot

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);

    }

}

 

注:上面配置的是TopicExchangeui

实际业务中,能够配置多个队列和binding来知足需求。spa

生产者

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

 

消费者

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

RabbitMQ实战(一)Spring Boot 整合 RabbitMQ

 

运行项目

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

RabbitMQ实战(一)Spring Boot 整合 RabbitMQ
相关文章
相关标签/搜索