成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

三分鐘實現 Spring Boot 集成 RabbitMQ,實現消息隊列服務

開發 前端
Spring Boot提供了spring-bootstarter-amqp組件對消息隊列進行支持,使用非常簡單,僅需要非常少的配置即可實現完整的消息隊列服務。

 [[424312]]

消息中間件在互聯網公司使用的越來越多,主要用于在分布式系統中存儲轉發消息,在易用性、擴展性、高可用性等方面表現不俗。消息隊列實現系統之間的雙向解耦,生產者往消息隊列中發送消息,消費者從隊列中拿取消息并處理,生產者不用關心是誰來消費,消費者不用關心誰在生產消息,從而達到系統解耦的目的,也大大提高了系統的高可用性和高并發能力。

接下來介紹Spring Boot對RabbitMQ的支持。如何在SpringBoot項目中使用RabbitMQ?

Spring Boot提供了spring-bootstarter-amqp組件對消息隊列進行支持,使用非常簡單,僅需要非常少的配置即可實現完整的消息隊列服務。

一、Spring Boot集成RabbitMQ

Spring Boot提供了spring-boot-starter-amqp組件,只需要簡單的配置即可與Spring Boot無縫集成。下面通過示例演示集成RabbitMQ實現消息的接收和發送。

第一步,配置pom包。

創建Spring Boot項目并在pom.xml文件中添加spring-bootstarter-amqp等相關組件依賴:

  1. <dependency> 
  2.  
  3. <groupId>org.springframework.boot</groupId> 
  4.  
  5. <artifactId>spring-boot-starter-amqp</artifactId> 
  6.  
  7. </dependency> 

在上面的示例中,引入Spring Boot自帶的amqp組件spring-bootstarter-amqp。

第二步,修改配置文件。

修改application.properties配置文件,配置rabbitmq的host地址、端口以及賬戶信息。

  1. spring.rabbitmq.host=10.2.1.231 
  2.  
  3. spring.rabbitmq.port=5672 
  4.  
  5. spring.rabbitmq.username=zhangweizhong 
  6.  
  7. spring.rabbitmq.password=weizhong1988 
  8.  
  9. spring.rabbitmq.virtualHost=order 

在上面的示例中,主要配置RabbitMQ服務的地址。RabbitMQ配置由spring.rabbitmq.*配置屬性控制。virtual-host配置項指定RabbitMQ服務創建的虛擬主機,不過這個配置項不是必需的。

第三步,創建消費者。

消費者可以消費生產者發送的消息。接下來創建消費者類Consumer,并使用@RabbitListener注解來指定消息的處理方法。示例代碼如下:

  1. @Component 
  2. public class Consumer { 
  3.  
  4.     @RabbitHandler 
  5.     @RabbitListener(queuesToDeclare = @Queue("rabbitmq_queue")) 
  6.     public void process(String message) { 
  7.         System.out.println("消費者消費消息111=====" + message); 
  8.     } 
  9.  

在上面的示例中,Consumer消費者通過@RabbitListener注解創建偵聽器端點,綁定rabbitmq_queue隊列。

(1)@RabbitListener注解提供了@QueueBinding、@Queue、@Exchange等對象,通過這個組合注解配置交換機、綁定路由并且配置監聽功能等。

(2)@RabbitHandler注解為具體接收的方法。

第四步,創建生產者。

生產者用來產生消息并進行發送,需要用到RabbitTemplate類。與之前的RedisTemplate類似,RabbitTemplate是實現發送消息的關鍵類。示例代碼如下:

  1. @Component 
  2. public class Producer { 
  3.  
  4.     @Autowired 
  5.     private RabbitTemplate rabbitTemplate; 
  6.      
  7.     public void produce() { 
  8.         String message = new Date() + "Beijing"
  9.         System.out.println("生產者產生消息=====" + message); 
  10.         rabbitTemplate.convertAndSend("rabbitmq_queue", message); 
  11.     } 

如上面的示例所示,RabbitTemplate提供了 convertAndSend方法發送消息。convertAndSend方法有routingKey和message兩個參數:

(1)routingKey為要發送的路由地址。

(2)message為具體的消息內容。發送者和接收者的queuename必須一致,不然無法接收。

最后,測試驗證。

創建對應的測試類ApplicationTests,驗證消息發送和接收是否成功。

  1. @RunWith(SpringRunner.class
  2. @SpringBootTest 
  3. public class ApplicationTests { 
  4.  
  5.     @Autowired 
  6.     Producer producer; 
  7.  
  8.     @Test 
  9.     public void contextLoads() throws InterruptedException { 
  10.         producer.produce();  
  11.         Thread.sleep(1*1000); 
  12.  
  13.     } 

在上面的示例中,首先注入生產者對象,然后調用produce()方法來發送消息。

最后,單擊Run Test或在方法上右擊,選擇Run 'contextLoads()',運行單元測試程序,查看后臺輸出情況,結果如下圖所示。

通過上面的程序輸出日志可以看到,消費者已經收到了生產者發送的消息并進行了處理。這是常用的簡單使用示例。

二、發送和接收實體對象

Spring Boot支持對象的發送和接收,且不需要額外的配置。下面通過一個例子來演示RabbitMQ發送和接收實體對象。

1. 定義實體類

首先,定義發送與接收的對象實體User類,代碼如下:

  1. public class User implements Serializable { 
  2.  
  3.     public String name; 
  4.  
  5.     public String password; 
  6.  
  7.     // 省略get和set方法 
  8.  

在上面的示例中,定義了普通的User實體對象。需要注意的是,實體類對象必須繼承Serializable序列化接口,否則會報數據無法序列化的錯誤。

2. 定義消費者

修改Consumer類,將參數換成User對象。示例代碼如下:

  1. @Component 
  2. public class Consumer { 
  3.  
  4.     @RabbitHandler 
  5.     @RabbitListener(queuesToDeclare = @Queue("rabbitmq_queue_object")) 
  6.     public void process(User user) { 
  7.         System.out.println("消費者消費消息111user=====name:" + user.getName()+",password:"+user.getPassword()); 
  8.      
  9.     } 

其實,消費者類和消息處理方法和之前的類似,只不過將參數換成了實體對象,監聽rabbitmq_queue_object隊列。

3. 定義生產者

修改Producer類,定義User實體對象,并通過convertAndSend方法發送對象消息。示例代碼如下:

  1. @Component 
  2. public class Producer { 
  3.  
  4.     @Autowired 
  5.     private RabbitTemplate rabbitTemplate; 
  6.      
  7.     public void produce() {  
  8.         User user=new User(); 
  9.         user.setName("weiz"); 
  10.         user.setPassword("123456"); 
  11.         System.out.println("生產者生產消息111=====" + user); 
  12.          
  13.         rabbitTemplate.convertAndSend("rabbitmq_queue_object", user); 
  14.     } 
  15.  

在上面的示例中,還是調用convertAndSend()方法發送實體對象。convertAndSend()方法支持String、Integer、Object等基礎的數據類型。

4. 驗證測試

創建單元測試類,注入生產者對象,然后調用produceObj()方法發送實體對象消息,從而驗證消息能否被成功接收。

  1. @RunWith(SpringRunner.class
  2. @SpringBootTest 
  3. public class ApplicationTests { 
  4.  
  5.     @Autowired 
  6.     Producer producer; 
  7.  
  8.     @Test 
  9.     public void testProduceObj() throws InterruptedException { 
  10.         producer.produceObj(); 
  11.         Thread.sleep(1*1000); 
  12.     } 

最后,單擊Run Test或在方法上右擊,選擇Run 'contextLoads()',運行單元測試程序,查看后臺輸出情況,運行結果如圖12-8所示。

通過上面的示例成功實現了RabbitMQ發送和接收實體對象,使得消息的數據結構更加清晰,也更加貼合面向對象的編程思想。

 

責任編輯:張燕妮 來源: 架構師精進
相關推薦

2024-04-01 09:59:08

消息隊列通信微服務

2024-09-13 08:49:45

2024-03-28 08:07:42

RabbitMQ訂閱模式

2022-02-16 19:42:25

Spring配置開發

2024-06-06 08:50:43

2023-12-23 18:04:40

服務Eureka工具

2023-08-01 09:01:51

Broker? 事務消息selector

2023-08-24 09:01:25

消息拉取RocketMQ

2023-08-14 09:16:26

消息存儲磁盤

2024-05-16 11:13:16

Helm工具release

2009-11-09 12:55:43

WCF事務

2024-12-18 10:24:59

代理技術JDK動態代理

2022-02-21 18:16:38

Go語言枚舉

2024-01-16 07:46:14

FutureTask接口用法

2021-04-20 13:59:37

云計算

2022-02-17 09:24:11

TypeScript編程語言javaScrip

2024-08-30 08:50:00

2023-12-27 08:15:47

Java虛擬線程

2025-03-26 01:35:00

tabs開發組件

2024-09-02 00:03:00

tabs組件CSS
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 九九免费视频 | 99热99| 日本涩涩视频 | 久热9| 成人深夜福利网站 | 久久青青 | 午夜影院在线播放 | 午夜视频网站 | 国产午夜影院 | 久久久久久久久国产精品 | 视频1区| 久久精品国产免费一区二区三区 | 中文字幕国产精品 | 欧美性受xxx | 午夜视频网| 中文字幕乱码一区二区三区 | 免费观看毛片 | 91中文视频 | 亚洲一区不卡 | 综合色站导航 | 日韩视频在线观看中文字幕 | 国产视频一区二区 | 欧美日韩亚洲一区 | av一区二区三区 | 欧美1区| 毛片一区二区 | 亚洲一区二区三区观看 | 91在线免费观看网站 | 6080yy精品一区二区三区 | 精品一区二区三区在线观看国产 | 男女午夜激情视频 | 国产精品国产亚洲精品看不卡15 | 日韩午夜一区二区三区 | 黄色激情毛片 | 午夜99| 亚洲视频在线观看 | 国产二区三区 | 午夜av电影 | 午夜影院在线观看视频 | 国产男女视频网站 | 天天天操操操 |