這篇文章主要介紹了Spring Boot整合RabbitMQ開發(fā)的示例分析,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
創(chuàng)新互聯(lián)長期為近千家客戶提供的網(wǎng)站建設服務,團隊從業(yè)經(jīng)驗10年,關注不同地域、不同群體,并針對不同對象提供差異化的產品和服務;打造開放共贏平臺,與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為西湖企業(yè)提供專業(yè)的成都做網(wǎng)站、成都網(wǎng)站設計,西湖網(wǎng)站改版等技術服務。擁有十多年豐富建站經(jīng)驗和眾多成功案例,為您定制開發(fā)。
RabbitMQ 中的一些術語
如果你打開 RabbitMQ web 控制臺,你會發(fā)現(xiàn)其中有一個 Exhanges 不好理解。下面簡單說明一下。

交換器(Exchange)
交換器就像路由器,我們先是把消息發(fā)到交換器,然后交換器再根據(jù)路由鍵(routingKey)把消息投遞到對應的隊列。(明白這個概念很重要,后面的代碼里面充分體現(xiàn)了這一點)
隊列(Queue)
隊列很好理解,就不用解釋了。
綁定(Binding)
交換器怎么知道把這條消息投遞到哪個隊列呢?這就需要用到綁定了。大概就是:使用某個路由鍵(routingKey)把某個隊列(Queue)綁定到某個交換器(Exchange),這樣交換器就知道根據(jù)路由鍵把這條消息投遞到哪個隊列了。(后面的代碼里面充分體現(xiàn)了這一點)
加入 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 配置
@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 ROUTING_KEY = "spring-boot-key";
// 創(chuàng)建隊列
@Bean
public Queue queue() {
return new Queue(QUEUE_NAME);
}
// 創(chuàng)建一個 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 方法就可以了。從下面的代碼里也可以看出,我們不是把消息直接發(fā)送到隊列里面的,而是先發(fā)送到了交換器,交換器再根據(jù)路由鍵把我們的消息投遞到對應的隊列。
@RestController
public 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 注解,指定需要監(jiān)聽的隊列名稱即可。
@Component
public class Consumer {
@RabbitListener(queues = RabbitMQConfig.QUEUE_NAME)
public void consumeMessage(String message) {
Console.log("consume message {}", message);
}
}運行項目
運行項目,然后打開瀏覽器,輸入 http://localhost:9999/sendMessage 。在控制臺就可以看到生產者在不停的的發(fā)送消息,消費者不斷的在消費消息。

打開 RabbitMQ web 控制臺,也可以看到剛才我們在代碼里面配置的交換器和隊列,以及綁定信息。

點擊進入交換器的詳情


感謝你能夠認真閱讀完這篇文章,希望小編分享的“Spring Boot整合RabbitMQ開發(fā)的示例分析”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián),關注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關知識等著你來學習!
新聞名稱:SpringBoot整合RabbitMQ開發(fā)的示例分析
文章起源:http://www.chinadenli.net/article18/pgsdgp.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供虛擬主機、網(wǎng)站建設、服務器托管、網(wǎng)站收錄、用戶體驗、網(wǎng)站維護
聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)