Spring Boot整合消息隊(duì)列RabbitMQ的實(shí)現(xiàn)示例
RabbitMQ 簡(jiǎn)介與安裝
1. RabbitMQ 簡(jiǎn)介
RabbitMQ 是一個(gè)開源的消息代理和隊(duì)列服務(wù)器,基于 AMQP(高級(jí)消息隊(duì)列協(xié)議)實(shí)現(xiàn)。它具有以下特點(diǎn):
- 可靠性:支持持久化、傳輸確認(rèn)、發(fā)布確認(rèn)等機(jī)制,確保消息不丟失。
- 靈活性:支持多種消息模型,如點(diǎn)對(duì)點(diǎn)、發(fā)布 - 訂閱等。
- 分布式:可以通過集群和鏡像隊(duì)列來(lái)實(shí)現(xiàn)高可用性和擴(kuò)展性。
- 多語(yǔ)言支持:支持多種編程語(yǔ)言,如 Java、Python、C# 等。
2. RabbitMQ 安裝
以下以在 Linux(Ubuntu)系統(tǒng)上安裝 RabbitMQ 為例:
步驟 1:安裝 ErlangRabbitMQ 是用 Erlang 語(yǔ)言編寫的,因此需要先安裝 Erlang。
# 添加 Erlang 倉(cāng)庫(kù) wget https://packages.erlang-solutions.com/erlang-solutions_2.0_all.deb sudo dpkg -i erlang-solutions_2.0_all.deb sudo apt-get update # 安裝 Erlang sudo apt-get install esl-erlang
步驟 2:安裝 RabbitMQ
# 添加 RabbitMQ 倉(cāng)庫(kù) echo "deb https://dl.bintray.com/rabbitmq/debian $(lsb_release -sc) main" | sudo tee /etc/apt/sources.list.d/bintray.rabbitmq.list wget -O- https://dl.bintray.com/rabbitmq/Keys/rabbitmq-release-signing-key.asc | sudo apt-key add - wget -O- https://www.rabbitmq.com/rabbitmq-release-signing-key.asc | sudo apt-key add - sudo apt-get update # 安裝 RabbitMQ sudo apt-get install rabbitmq-server
步驟 3:?jiǎn)?dòng) RabbitMQ 服務(wù)
sudo systemctl start rabbitmq-server
步驟 4:設(shè)置開機(jī)自啟
sudo systemctl enable rabbitmq-server
步驟 5:?jiǎn)⒂霉芾斫缑?/strong>
sudo rabbitmq-plugins enable rabbitmq_management
訪問 http://localhost:15672
,使用默認(rèn)用戶名 guest
和密碼 guest
登錄管理界面。
Spring Boot 集成 RabbitMQ
1. 創(chuàng)建 Spring Boot 項(xiàng)目
可以使用 Spring Initializr(https://start.spring.io/)創(chuàng)建一個(gè)新的 Spring Boot 項(xiàng)目,添加以下依賴:
- Spring Web
- Spring AMQP
2. 配置 RabbitMQ
在 application.properties
或 application.yml
中配置 RabbitMQ 連接信息:
application.properties
spring.rabbitmq.host=localhost spring.rabbitmq.port=5672 spring.rabbitmq.username=guest spring.rabbitmq.password=guest
application.yml
spring: rabbitmq: host: localhost port: 5672 username: guest password: guest
3. 定義消息隊(duì)列和交換機(jī)
創(chuàng)建一個(gè)配置類來(lái)定義隊(duì)列、交換機(jī)和綁定關(guān)系:
import org.springframework.amqp.core.Binding; import org.springframework.amqp.core.BindingBuilder; import org.springframework.amqp.core.DirectExchange; import org.springframework.amqp.core.Queue; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; @Configuration public class RabbitMQConfig { public static final String QUEUE_NAME = "myQueue"; public static final String EXCHANGE_NAME = "myExchange"; public static final String ROUTING_KEY = "myRoutingKey"; @Bean public Queue queue() { return new Queue(QUEUE_NAME, true); } @Bean public DirectExchange exchange() { return new DirectExchange(EXCHANGE_NAME); } @Bean public Binding binding(Queue queue, DirectExchange exchange) { return BindingBuilder.bind(queue).to(exchange).with(ROUTING_KEY); } }
4. 發(fā)送消息
創(chuàng)建一個(gè)消息發(fā)送者類:
import org.springframework.amqp.rabbit.core.RabbitTemplate; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; @Service public class MessageSender { @Autowired private RabbitTemplate rabbitTemplate; public void sendMessage(String message) { rabbitTemplate.convertAndSend(RabbitMQConfig.EXCHANGE_NAME, RabbitMQConfig.ROUTING_KEY, message); } }
5. 接收消息
創(chuàng)建一個(gè)消息接收者類:
import org.springframework.amqp.rabbit.annotation.RabbitListener; import org.springframework.stereotype.Service; @Service public class MessageReceiver { @RabbitListener(queues = RabbitMQConfig.QUEUE_NAME) public void receiveMessage(String message) { System.out.println("Received message: " + message); } }
6. 測(cè)試消息發(fā)送和接收
創(chuàng)建一個(gè)控制器來(lái)測(cè)試消息發(fā)送:
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; @RestController public class MessageController { @Autowired private MessageSender messageSender; @GetMapping("/send") public String sendMessage(@RequestParam String message) { messageSender.sendMessage(message); return "Message sent: " + message; } }
啟動(dòng) Spring Boot 應(yīng)用程序,訪問 http://localhost:8080/send?message=Hello,RabbitMQ
,在控制臺(tái)可以看到消息接收的輸出。
通過以上步驟,就完成了 Spring Boot 與 RabbitMQ 的集成,實(shí)現(xiàn)了消息的發(fā)送和接收。
到此這篇關(guān)于Spring Boot整合消息隊(duì)列RabbitMQ的實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)Spring Boot 消息隊(duì)列RabbitMQ內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java ArrayBlockingQueue阻塞隊(duì)列的實(shí)現(xiàn)示例
ArrayBlockingQueue是一個(gè)基于數(shù)組實(shí)現(xiàn)的阻塞隊(duì)列,本文就來(lái)介紹一下java ArrayBlockingQueue阻塞隊(duì)列的實(shí)現(xiàn)示例,具有一定的參考價(jià)值,感興趣的可以了解一下2024-02-02Spring Data JPA 簡(jiǎn)單查詢--方法定義規(guī)則(詳解)
下面小編就為大家?guī)?lái)一篇Spring Data JPA 簡(jiǎn)單查詢--方法定義規(guī)則(詳解)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧2017-04-04如何解決SpringBoot啟動(dòng)時(shí)無(wú)法加載配置文件或環(huán)境變量問題
文章主要介紹了在Spring Boot項(xiàng)目中遇到配置文件加載失敗和資源目錄圖標(biāo)異常的問題,并提供了詳細(xì)的解決步驟,解決方法包括在pom.xml文件中添加特定配置,確保資源目錄順序正確,以及注意節(jié)點(diǎn)的正確使用,通過這些步驟,可以有效解決資源加載問題,提高開發(fā)效率2024-12-12java在cmd運(yùn)行"-d"和"-cp"參數(shù)解讀
這篇文章主要介紹了java在cmd運(yùn)行"-d"和"-cp"參數(shù)用法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08Java實(shí)現(xiàn)簡(jiǎn)易計(jì)算器(逆波蘭表達(dá)式)
這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)簡(jiǎn)易計(jì)算器,逆波蘭表達(dá)式,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07Spring Boot如何通過java -jar啟動(dòng)
大家開發(fā)的基于Spring Boot 的應(yīng)用 ,jar形式, 發(fā)布的時(shí)候,絕大部分都是使用java -jar 啟動(dòng)。本文主要介紹了Spring Boot如何通過java -jar啟動(dòng),一起來(lái)了解一下2021-05-05