這篇文章主要講基本的整合。先把代碼跑起來,再說什麼高級特性。
RabbitMQ 中的一些術語
如果你打開RabbitMQ web 控制台,你會發現其中有一個Exhanges 不好理解。下面簡單說明一下。
交換器(Exchange)
交換器就像路由器,我們先是把消息發到交換器,然後交換器再根據路由鍵(routingKey)把消息投遞到對應的隊列。 (明白這個概念很重要,後面的代碼裡面充分體現了這一點)
隊列(Queue)
隊列很好理解,就不用解釋了。
綁定(Binding)
交換器怎麼知道把這條消息投遞到哪個隊列呢?這就需要用到綁定了。大概就是:使用某個路由鍵(routingKey)把某個隊列(Queue)綁定到某個交換器(Exchange),這樣交換器就知道根據路由鍵把這條消息投遞到哪個隊列了。 (後面的代碼裡面充分體現了這一點)
加入RabbitMQ maven 依賴
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-amqp</artifactId></dependency>
再加入另外一個依賴(這個依賴可省略,主要是用來簡化代碼)
<dependency> <groupId>cn.hutool</groupId> <artifactId>hutool-all</artifactId> <version>4.0.2</version></dependency>
RabbitMQConfig.java 配置
@Configurationpublic class RabbitMQConfig { public final static String QUEUE_NAME = "spring-boot-queue"; public final static String EXCHANGE_NAME = "spring-boot-exchange"; public final static String ROUTING_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(ROUTING_KEY); } @Bean public ConnectionFactory connectionFactory() { CachingConnectionFactory connectionFactory = new CachingConnectionFactory("127.0.0.1", 5672); connectionFactory.setUsername("guest"); connectionFactory.setPassword("guest"); return connectionFactory; } @Bean public RabbitTemplate rabbitTemplate(ConnectionFactory connectionFactory) { return new RabbitTemplate(connectionFactory); }}生產者
直接調用rabbitTemplate 的convertAndSend 方法就可以了。從下面的代碼裡也可以看出,我們不是把消息直接發送到隊列裡面的,而是先發送到了交換器,交換器再根據路由鍵把我們的消息投遞到對應的隊列。
@RestControllerpublic class ProducerController { @Autowired private RabbitTemplate rabbitTemplate; @GetMapping("/sendMessage") public Object 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 註解,指定需要監聽的隊列名稱即可。
@Componentpublic class Consumer { @RabbitListener(queues = RabbitMQConfig.QUEUE_NAME) public void consumeMessage(String message) { Console.log("consume message {}", message); }}運行項目
運行項目,然後打開瀏覽器,輸入http://localhost:9999/sendMessage 。在控制台就可以看到生產者在不停的的發送消息,消費者不斷的在消費消息。
打開RabbitMQ web 控制台,也可以看到剛才我們在代碼裡面配置的交換器和隊列,以及綁定信息。
點擊進入交換器的詳情
結語
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。