spring boot整合RabbitMQ(Direct模式)
springboot集成RabbitMQ非常簡單,如果只是簡單的使用配置非常少,springboot提供了spring-boot-starter-amqp項目對消息各種支持。
1.新建一個Spring Boot工程,命名為:“rabbitmq-hello”。
在pom.xml中引入如下依賴內(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的連接和用戶信息,用戶可以回到上面的安裝內(nèi)容,在管理頁面中創(chuàng)建用戶。
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。通過注入AmqpTemplate接口的實例來實現(xiàn)消息的發(fā)送,AmqpTemplate接口定義了一套針對AMQP協(xié)議的基礎(chǔ)操作。
在Spring Boot中會根據(jù)配置來注入其具體實現(xiàn)。在該生產(chǎn)者,我們會產(chǎn)生一個字符串,并發(fā)送到名為hello的隊列中。
@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)建消息消費者Receiver。
通過@RabbitListener注解定義該類對hello隊列的監(jiān)聽,并用@RabbitHandler注解來指定對消息的處理方法。所以,該消費者實現(xiàn)了對hello隊列的消費,消費操作為輸出消息的字符串內(nèi)容。
@Component
@RabbitListener(queues = "hello")
public class Receiver {
@RabbitHandler
public void process(String hello) {
System.out.println("Receiver : " + hello);
}
}
5.創(chuàng)建RabbitMQ的配置類RabbitConfig,用來配置隊列、交換器、路由等高級信息。這里我們以入門為主,先以最小化的配置來定義,以完成一個基本的生產(chǎn)和消費過程。
@Configuration
public class RabbitConfig {
@Bean
public Queue helloQueue() {
return new Queue("hello");
}
}
6.創(chuàng)建應(yīng)用主類:
@SpringBootApplication
public class HelloApplication {
public static void main(String[] args) {
SpringApplication.run(HelloApplication.class, args);
}
}
7.創(chuàng)建單元測試類,用來調(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.啟動應(yīng)用主類,從控制臺中,我們看到如下內(nèi)容,程序創(chuàng)建了一個訪問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/]
同時,我們通過RabbitMQ的控制面板,可以看到Connection和Channels中包含當(dāng)前連接的條目。
9.運行單元測試類,我們可以看到控制臺中輸出下面的內(nèi)容,消息被發(fā)送到了RabbitMQ Server的hello隊列中。
Sender : hello Sun Sep 25 11:06:11 CST 2016
10.切換到應(yīng)用主類的控制臺,我們可以看到類似如下輸出,消費者對hello隊列的監(jiān)聽程序執(zhí)行了,并輸出了接受到的消息信息。
Receiver : hello Sun Sep 25 11:06:11 CST 2016
通過上面的示例,我們在Spring Boot應(yīng)用中引入spring-boot-starter-amqp模塊,進行簡單配置就完成了對RabbitMQ的消息生產(chǎn)和消費的開發(fā)內(nèi)容。
需要注意的地方,Direct模式相當(dāng)于一對一模式,一個消息被發(fā)送者發(fā)送后,會被轉(zhuǎn)發(fā)到一個綁定的消息隊列中,然后被一個接收者接收!
實際上RabbitMQ還可以支持發(fā)送對象:當(dāng)然由于涉及到序列化和反序列化,該對象要實現(xiàn)Serilizable接口.HelloSender做出如下改寫:
public void send() {
User user=new User(); //實現(xiàn)Serializable接口
user.setUsername("hlhdidi");
user.setPassword("123");
template.convertAndSend("queue",user);
}
HelloReceiver做出如下改寫:
@RabbitListener(queues="queue") //監(jiān)聽器監(jiān)聽指定的Queue
public void process1(User user) { //用User作為參數(shù)
System.out.println("Receive1:"+user);
}
以上所述是小編給大家介紹的spring boot整合RabbitMQ(Direct模式),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
使用Spring?Boot如何限制在一分鐘內(nèi)某個IP只能訪問10次
有些時候,為了防止我們上線的網(wǎng)站被攻擊,或者被刷取流量,我們會對某一個ip進行限制處理,這篇文章,我們將通過Spring?Boot編寫一個小案例,來實現(xiàn)在一分鐘內(nèi)同一個IP只能訪問10次,感興趣的朋友一起看看吧2023-10-10
Java8學(xué)習(xí)教程之lambda表達式語法介紹
眾所周知lambda表達式是JAVA8中提供的一種新的特性,它支持Java也能進行簡單的“函數(shù)式編程”。 下面這篇文章主要給大家介紹了關(guān)于Java8學(xué)習(xí)教程之lambda表達式語法的相關(guān)資料,需要的朋友可以參考下。2017-09-09
java返回前端實體類json數(shù)據(jù)時忽略某個屬性方法
這篇文章主要給大家介紹了關(guān)于java返回前端實體類json數(shù)據(jù)時忽略某個屬性的相關(guān)資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下2023-08-08
java學(xué)生信息管理系統(tǒng)設(shè)計
這篇文章主要為大家詳細介紹了java學(xué)生信息管理系統(tǒng)設(shè)計,學(xué)生信息添加進入數(shù)據(jù)庫的事務(wù),具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-11-11
Java FineReport報表工具導(dǎo)出EXCEL的四種方式
這篇文章主要介紹了Java FineReport報表工具導(dǎo)出EXCEL的四種方式的相關(guān)資料,需要的朋友可以參考下2016-03-03

