spring boot整合RabbitMQ(Direct模式)
springboot集成RabbitMQ非常簡(jiǎn)單,如果只是簡(jiǎn)單的使用配置非常少,springboot提供了spring-boot-starter-amqp項(xiàng)目對(duì)消息各種支持。
1.新建一個(gè)Spring Boot工程,命名為:“rabbitmq-hello”。
在pom.xml中引入如下依賴(lài)內(nèi)容,其中spring-boot-starter-amqp用于支持RabbitMQ。
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-amqp</artifactId> </dependency>
2.在application.properties中配置關(guān)于RabbitMQ的連接和用戶(hù)信息,用戶(hù)可以回到上面的安裝內(nèi)容,在管理頁(yè)面中創(chuàng)建用戶(hù)。
spring.application.name=rabbitmq-hello spring.rabbitmq.host=localhost spring.rabbitmq.port=5672 spring.rabbitmq.username=admin spring.rabbitmq.password=123456
3.創(chuàng)建消息生產(chǎn)者Sender。通過(guò)注入AmqpTemplate接口的實(shí)例來(lái)實(shí)現(xiàn)消息的發(fā)送,AmqpTemplate接口定義了一套針對(duì)AMQP協(xié)議的基礎(chǔ)操作。
在Spring Boot中會(huì)根據(jù)配置來(lái)注入其具體實(shí)現(xiàn)。在該生產(chǎn)者,我們會(huì)產(chǎn)生一個(gè)字符串,并發(fā)送到名為hello的隊(duì)列中。
@Component public class Sender { @Autowired private AmqpTemplate rabbitTemplate; public void send() { String context = "hello " + new Date(); System.out.println("Sender : " + context); this.rabbitTemplate.convertAndSend("hello", context); } }
4.創(chuàng)建消息消費(fèi)者Receiver。
通過(guò)@RabbitListener注解定義該類(lèi)對(duì)hello隊(duì)列的監(jiān)聽(tīng),并用@RabbitHandler注解來(lái)指定對(duì)消息的處理方法。所以,該消費(fèi)者實(shí)現(xiàn)了對(duì)hello隊(duì)列的消費(fèi),消費(fèi)操作為輸出消息的字符串內(nèi)容。
@Component @RabbitListener(queues = "hello") public class Receiver { @RabbitHandler public void process(String hello) { System.out.println("Receiver : " + hello); } }
5.創(chuàng)建RabbitMQ的配置類(lèi)RabbitConfig,用來(lái)配置隊(duì)列、交換器、路由等高級(jí)信息。這里我們以入門(mén)為主,先以最小化的配置來(lái)定義,以完成一個(gè)基本的生產(chǎn)和消費(fèi)過(guò)程。
@Configuration public class RabbitConfig { @Bean public Queue helloQueue() { return new Queue("hello"); } }
6.創(chuàng)建應(yīng)用主類(lèi):
@SpringBootApplication public class HelloApplication { public static void main(String[] args) { SpringApplication.run(HelloApplication.class, args); } }
7.創(chuàng)建單元測(cè)試類(lèi),用來(lái)調(diào)用消息生產(chǎn):
@RunWith(SpringJUnit4ClassRunner.class) @SpringApplicationConfiguration(classes = HelloApplication.class) public class HelloApplicationTests { @Autowired private Sender sender; @Test public void hello() throws Exception { sender.send(); } }
8.啟動(dòng)應(yīng)用主類(lèi),從控制臺(tái)中,我們看到如下內(nèi)容,程序創(chuàng)建了一個(gè)訪問(wèn)127.0.0.1:5672中admin的連接。
o.s.a.r.c.CachingConnectionFactory : Created new connection: SimpleConnection@29836d32 [delegate=amqp://admin@127.0.0.1:5672/]
同時(shí),我們通過(guò)RabbitMQ的控制面板,可以看到Connection和Channels中包含當(dāng)前連接的條目。
9.運(yùn)行單元測(cè)試類(lèi),我們可以看到控制臺(tái)中輸出下面的內(nèi)容,消息被發(fā)送到了RabbitMQ Server的hello隊(duì)列中。
Sender : hello Sun Sep 25 11:06:11 CST 2016
10.切換到應(yīng)用主類(lèi)的控制臺(tái),我們可以看到類(lèi)似如下輸出,消費(fèi)者對(duì)hello隊(duì)列的監(jiān)聽(tīng)程序執(zhí)行了,并輸出了接受到的消息信息。
Receiver : hello Sun Sep 25 11:06:11 CST 2016
通過(guò)上面的示例,我們?cè)赟pring Boot應(yīng)用中引入spring-boot-starter-amqp模塊,進(jìn)行簡(jiǎn)單配置就完成了對(duì)RabbitMQ的消息生產(chǎn)和消費(fèi)的開(kāi)發(fā)內(nèi)容。
需要注意的地方,Direct模式相當(dāng)于一對(duì)一模式,一個(gè)消息被發(fā)送者發(fā)送后,會(huì)被轉(zhuǎn)發(fā)到一個(gè)綁定的消息隊(duì)列中,然后被一個(gè)接收者接收!
實(shí)際上RabbitMQ還可以支持發(fā)送對(duì)象:當(dāng)然由于涉及到序列化和反序列化,該對(duì)象要實(shí)現(xiàn)Serilizable接口.HelloSender做出如下改寫(xiě):
public void send() { User user=new User(); //實(shí)現(xiàn)Serializable接口 user.setUsername("hlhdidi"); user.setPassword("123"); template.convertAndSend("queue",user); } HelloReceiver做出如下改寫(xiě): @RabbitListener(queues="queue") //監(jiān)聽(tīng)器監(jiān)聽(tīng)指定的Queue public void process1(User user) { //用User作為參數(shù) System.out.println("Receive1:"+user); }
以上所述是小編給大家介紹的spring boot整合RabbitMQ(Direct模式),希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- springboot X-Accel-Redirect 大文件下載實(shí)現(xiàn)
- springboot如何重定向攜帶數(shù)據(jù) RedirectAttributes
- springboot 重定向方式(redirect前綴)
- 基于springboot redirect重定向路徑問(wèn)題總結(jié)
- springboot 如何重定向redirect 并隱藏參數(shù)
- C#使用RabbitMq隊(duì)列(Sample,Work,Fanout,Direct等模式的簡(jiǎn)單使用)
- rabbitmq使用springboot實(shí)現(xiàn)direct模式(最新推薦)
相關(guān)文章
基于jQuery獲取table數(shù)據(jù)發(fā)送到后端
這篇文章主要介紹了基于jQuery獲取table數(shù)據(jù)發(fā)送到后端,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-02-02SpringBoot+SpringCache實(shí)現(xiàn)兩級(jí)緩存(Redis+Caffeine)
這篇文章主要介紹了SpringBoot+SpringCache實(shí)現(xiàn)兩級(jí)緩存(Redis+Caffeine),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04關(guān)于Spring?@Transactional事務(wù)傳播機(jī)制詳解
我們?nèi)粘9ぷ髦袠O少使用事務(wù)傳播級(jí)別,單純只是使用事務(wù)和rollbackfor拋出異常來(lái)解決事務(wù)問(wèn)題,但其實(shí)我們很多時(shí)候使用的是不正確的,或者說(shuō)會(huì)造成事務(wù)粒度過(guò)大,本文詳解一下事務(wù)傳播級(jí)別,也讓自己更好地處理事務(wù)問(wèn)題,需要的朋友可以參考下2023-08-08Java修飾符 abstract,static,final 的區(qū)別詳解
以下是對(duì)Java修飾符abstract,static,final的區(qū)別進(jìn)行了詳細(xì)的介紹,需要的朋友可以過(guò)來(lái)參考下2013-09-09阿里云主機(jī)上安裝jdk 某庫(kù)出現(xiàn)問(wèn)題的解決方法
今天安裝jdk到阿里云服務(wù)上,首先看下阿里云是32位還是64位的,如果是32位下載32位的包,如果是64位的下載64位的包,下面與大家分享下安裝過(guò)程中遇到問(wèn)題的解決方法2013-06-06Java日常練習(xí)題,每天進(jìn)步一點(diǎn)點(diǎn)(44)
下面小編就為大家?guī)?lái)一篇Java基礎(chǔ)的幾道練習(xí)題(分享)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧,希望可以幫到你2021-07-07java 利用反射機(jī)制,獲取實(shí)體所有屬性和方法,并對(duì)屬性賦值
這篇文章主要介紹了 java 利用反射機(jī)制,獲取實(shí)體所有屬性和方法,并對(duì)屬性賦值的相關(guān)資料,需要的朋友可以參考下2017-01-01