本文主要介紹RabbitMQ基礎組件和SpringBoot整合RabbitMQ簡單示例java
交換器就像路由器,咱們先是把消息發到交換器,而後交換器再根據綁定鍵(binding key)和生產者發送消息時的路由鍵routingKey,spring
按照交換類型Exchange Type(fanout,direct,topic)把消息投遞到對應的隊列。(明白這個概念很重要,後面的代碼裏面充分體現了這一點)。瀏覽器
RabbitMQ基礎知識可查看消息隊列RabbitMQ基礎知識詳解服務器
存放消息的隊列。app
交換器怎麼知道把這條消息投遞到哪一個隊列呢?這就須要用到綁定了。大概就是:使用某個綁定鍵(binding key),把某個隊列(Queue)綁定到某個交換器(Exchange),這樣交換器就知道根據路由鍵把這條消息投遞到哪一個隊列了。(後面的代碼裏面充分體現了這一點)maven
application.yaml文件中配置spring-boot
@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 註解,指定須要監聽的隊列名稱便可。
運行項目,而後打開瀏覽器,輸入 http://localhost:9999/sendMessage(具體地址根據服務器)。在控制檯就能夠看到生產者在不停的的發送消息,消費者不斷的在消費消息。