Spring整合RabbitMQ詳解(生產(chǎn)者工程猛铅、消費(fèi)者工程)

1. Spring Boot整合RabbitMQ

1.1. 簡(jiǎn)介

在Spring項(xiàng)目中火架,可以使用Spring-Rabbit去操作RabbitMQ https://github.com/spring-projects/spring-amqp
尤其是在spring boot項(xiàng)目中只需要引入對(duì)應(yīng)的amqp啟動(dòng)器依賴即可馆匿,方便的使用RabbitTemplate發(fā)
送消息竭钝,使用注解接收消息梨撞。
一般在開發(fā)過程中:

生產(chǎn)者工程

  1. application.yml文件配置RabbitMQ相關(guān)信息雹洗;
  2. 在生產(chǎn)者工程中編寫配置類,用于創(chuàng)建交換機(jī)和隊(duì)列卧波,并進(jìn)行綁定
  3. 注入RabbitTemplate對(duì)象时肿,通過RabbitTemplate對(duì)象發(fā)送消息到交換機(jī)

消費(fèi)者工程

  1. application.yml文件配置RabbitMQ相關(guān)信息
  2. 創(chuàng)建消息處理類,用于接收隊(duì)列中的消息并進(jìn)行處理

1.2. 搭建生產(chǎn)者工程

1.2.1. 創(chuàng)建工程

創(chuàng)建生產(chǎn)者工程springboot-rabbitmq-producer



1.2.2. 添加依賴

修改pom.xml文件內(nèi)容為如下:

<?xml version="1.0" encoding="UTF-8"?> 
<project xmlns="http://maven.apache.org/POM/4.0.0" 
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 
http://maven.apache.org/xsd/maven-4.0.0.xsd"> 
<modelVersion>4.0.0</modelVersion> 
<parent> 
   <groupId>org.springframework.boot</groupId> 
   <artifactId>spring-boot-starter-parent</artifactId> 
   <version>2.1.4.RELEASE</version> 
</parent> 
<groupId>com.itheima</groupId> 
<artifactId>springboot-rabbitmq-producer</artifactId> 
<version>1.0-SNAPSHOT</version> 
<dependencies> 
<dependency> 
<groupId>org.springframework.boot</groupId> 
<artifactId>spring-boot-starter-web</artifactId> </dependency> 
<dependency> 
<groupId>org.springframework.boot</groupId> 
<artifactId>spring-boot-starter-amqp</artifactId> 
</dependency> 
</dependencies> 
</project>

1.2.3. 啟動(dòng)類

package com.itheima.rabbitmq; 
import org.springframework.boot.SpringApplication; 
import org.springframework.boot.autoconfigure.SpringBootApplication; 

@SpringBootApplication public class ProducerApplication { 
public static void main(String[] args) { 
SpringApplication.run(ProducerApplication.class); 
} 
}

1.2.4. 配置RabbitMQ

1)配置文件

創(chuàng)建application.yml港粱,內(nèi)容如下:

spring:
 rabbitmq:
 host: localhost 
port: 5672 
virtual-host: /itcast 
username: heima 
password: heima

2)綁定交換機(jī)和隊(duì)列

創(chuàng)建RabbitMQ隊(duì)列與交換機(jī)綁定的配置類com.itheima.rabbitmq.config.RabbitMQConfig

package com.itheima.rabbitmq.config; 
import org.springframework.amqp.core.*; 
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.context.annotation.Bean; 
import org.springframework.context.annotation.Configuration; 
@Configuration public class RabbitMQConfig { 
//交換機(jī)名稱 
public static final String ITEM_TOPIC_EXCHANGE = "item_topic_exchange"; 
//隊(duì)列名稱 
public static final String ITEM_QUEUE = "item_queue"; 
//聲明交換機(jī)
@Bean("itemTopicExchange") 
public Exchange topicExchange(){
 return 
ExchangeBuilder.topicExchange(ITEM_TOPIC_EXCHANGE).durable(true).build(); 
}
//聲明隊(duì)列 
@Bean("itemQueue") 
public Queue itemQueue(){ 
return QueueBuilder.durable(ITEM_QUEUE).build();
 }
//綁定隊(duì)列和交換機(jī) 
@Bean 
public Binding itemQueueExchange(@Qualifier("itemQueue") Queue queue,
                                                          @Qualifier("itemTopicExchange") Exchange 
exchange){
return BindingBuilder.bind(queue).to(exchange).with("item.#").noargs();
 }
 }

1.2.5 消息發(fā)送Controller

我們創(chuàng)建一個(gè)SpringMVC的Controller方便我們進(jìn)行測(cè)試

package com.itheima.rabbitmq.controller; 

import com.itheima.rabbitmq.config.RabbitMQConfig; 
import org.springframework.amqp.rabbit.core.RabbitTemplate; 
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping; 
import org.springframework.web.bind.annotation.RequestParam; 
import org.springframework.web.bind.annotation.RestController; 
/*** 
發(fā)送消息的測(cè)試類 
*/ 
@RestController 
public class SendMsgController { 
//注入RabbitMQ的模板 
@Autowired
 private RabbitTemplate rabbitTemplate; 
/*** 
測(cè)試 
*/ @GetMapping("/sendmsg") 
public String sendMsg(@RequestParam String msg, @RequestParam String key){ 
/**
* 發(fā)送消息 
* 參數(shù)一:交換機(jī)名稱 
* 參數(shù)二:路由key 
* 參數(shù)三:發(fā)送的消息 
*/ 
rabbitTemplate.convertAndSend(RabbitMQConfig.ITEM_TOPIC_EXCHANGE ,key ,msg); 
//返回消息 
return "發(fā)送消息成功螃成!"; 
} 
}

1.3. 搭建消費(fèi)者工程

1.3.1. 創(chuàng)建工程

創(chuàng)建消費(fèi)者工程springboot-rabbitmq-consumer



image.png

1.3.2. 添加依賴

修改pom.xml文件內(nèi)容為如下:

<?xml version="1.0" encoding="UTF-8"?> 
<project xmlns="http://maven.apache.org/POM/4.0.0" 
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 
http://maven.apache.org/xsd/maven-4.0.0.xsd"> 
<modelVersion>4.0.0</modelVersion> 
<parent> 
<groupId>org.springframework.boot</groupId> 
<artifactId>spring-boot-starter-parent</artifactId> <version>2.1.4.RELEASE</version> 
</parent> 
<groupId>com.itheima</groupId> 
<artifactId>springboot-rabbitmq-consumer</artifactId> 
<version>1.0-SNAPSHOT</version> 
<dependencies> 
<dependency> 
<groupId>org.springframework.boot</groupId> 
<artifactId>spring-boot-starter-web</artifactId> 
</dependency> 
<dependency> 
<groupId>org.springframework.boot</groupId> 
<artifactId>spring-boot-starter-amqp</artifactId> 
</dependency> 
</dependencies>

1.3.3. 啟動(dòng)類

1.3.4. 配置RabbitMQ

創(chuàng)建application.yml,內(nèi)容如下:

spring: 
rabbitmq: 
host: localhost 
port: 5672 
virtual-host: /itcast 
username: heima 
password: heima

1.3.5. 消息監(jiān)聽處理類

編寫消息監(jiān)聽器com.itheima.rabbitmq.listener.MyListener

package com.itheima.rabbitmq.listener; 
import org.springframework.amqp.rabbit.annotation.RabbitListener; 
import org.springframework.stereotype.Component; 
@Component 
public class MyListener { /*** 監(jiān)聽某個(gè)隊(duì)列的消息 * 
@param message 
接收到的消息 */ 
@RabbitListener(queues = "item_queue") 
public void myListener1(String message){
System.out.println("消費(fèi)者接收到的消息為:" + message); } }

1.3.6. 測(cè)試

image.png

在生產(chǎn)者工程springboot-rabbitmq-producer中創(chuàng)建測(cè)試類查坪,發(fā)送消息:

package com.itheima.rabbitmq; 
import com.itheima.rabbitmq.config.RabbitMQConfig; 
import org.junit.Test; import org.junit.runner.RunWith; 
import org.springframework.amqp.rabbit.core.RabbitTemplate; 
import org.springframework.beans.factory.annotation.Autowired; 
import org.springframework.boot.test.context.SpringBootTest; 
import org.springframework.test.context.junit4.SpringRunner; 
@RunWith(SpringRunner.class) 
@SpringBootTest 
public class RabbitMQTest { 
@Autowired 
private RabbitTemplate rabbitTemplate; 
@Test public void test(){ 
rabbitTemplate.convertAndSend(RabbitMQConfig.ITEM_TOPIC_EXCHANGE, 
"item.insert", "商品新增寸宏,routing key 為item.insert"); rabbitTemplate.convertAndSend(RabbitMQConfig.ITEM_TOPIC_EXCHANGE, 
"item.update", "商品修改,routing key 為item.update"); rabbitTemplate.convertAndSend(RabbitMQConfig.ITEM_TOPIC_EXCHANGE, 
"item.delete", "商品刪除咪惠,routing key 為item.delete");
 } 
}

先運(yùn)行上述測(cè)試程序(交換機(jī)和隊(duì)列才能先被聲明和綁定)击吱,然后啟動(dòng)消費(fèi)者;在消費(fèi)者工程
springboot-rabbitmq-consumer中控制臺(tái)查看是否接收到對(duì)應(yīng)消息遥昧。

另外覆醇;也可以在RabbitMQ的管理控制臺(tái)中查看到交換機(jī)與隊(duì)列的綁定:


image.png
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市炭臭,隨后出現(xiàn)的幾起案子永脓,更是在濱河造成了極大的恐慌,老刑警劉巖鞋仍,帶你破解...
    沈念sama閱讀 219,427評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件常摧,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡威创,警方通過查閱死者的電腦和手機(jī)落午,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,551評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來肚豺,“玉大人溃斋,你說我怎么就攤上這事∥辏” “怎么了梗劫?”我有些...
    開封第一講書人閱讀 165,747評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)截碴。 經(jīng)常有香客問我梳侨,道長(zhǎng),這世上最難降的妖魔是什么日丹? 我笑而不...
    開封第一講書人閱讀 58,939評(píng)論 1 295
  • 正文 為了忘掉前任走哺,我火速辦了婚禮,結(jié)果婚禮上哲虾,老公的妹妹穿的比我還像新娘丙躏。我一直安慰自己齐帚,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,955評(píng)論 6 392
  • 文/花漫 我一把揭開白布彼哼。 她就那樣靜靜地躺著,像睡著了一般湘今。 火紅的嫁衣襯著肌膚如雪敢朱。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,737評(píng)論 1 305
  • 那天摩瞎,我揣著相機(jī)與錄音拴签,去河邊找鬼。 笑死旗们,一個(gè)胖子當(dāng)著我的面吹牛蚓哩,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播上渴,決...
    沈念sama閱讀 40,448評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼岸梨,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了稠氮?” 一聲冷哼從身側(cè)響起曹阔,我...
    開封第一講書人閱讀 39,352評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎隔披,沒想到半個(gè)月后赃份,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,834評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡奢米,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,992評(píng)論 3 338
  • 正文 我和宋清朗相戀三年抓韩,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片鬓长。...
    茶點(diǎn)故事閱讀 40,133評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡谒拴,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出痢士,到底是詐尸還是另有隱情彪薛,我是刑警寧澤,帶...
    沈念sama閱讀 35,815評(píng)論 5 346
  • 正文 年R本政府宣布怠蹂,位于F島的核電站善延,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏城侧。R本人自食惡果不足惜易遣,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,477評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望嫌佑。 院中可真熱鬧豆茫,春花似錦侨歉、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,022評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至火脉,卻和暖如春牵舵,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背倦挂。 一陣腳步聲響...
    開封第一講書人閱讀 33,147評(píng)論 1 272
  • 我被黑心中介騙來泰國(guó)打工畸颅, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人方援。 一個(gè)月前我還...
    沈念sama閱讀 48,398評(píng)論 3 373
  • 正文 我出身青樓没炒,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親犯戏。 傳聞我的和親對(duì)象是個(gè)殘疾皇子送火,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,077評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容