天天訊息:使用 Spring Cloud Bus 和 Spring Cloud Stream 集成實現基于消息的事件驅動
基于消息的事件驅動是一種常見的微服務架構設計模式,它將不同的微服務之間通過消息進行通信,實現松耦合、高可伸縮性和高可靠性。在這種架構下,每個微服務都是獨立的,它們可以在消息傳遞的過程中進行異步操作,這使得整個系統的性能得到了很大的提升。
在 Spring Cloud 中,我們可以使用 Spring Cloud Bus 和 Spring Cloud Stream 集成來實現基于消息的事件驅動。Spring Cloud Bus 是一個消息總線,它可以在微服務之間傳遞消息,可以將所有微服務視為一個整體,向所有微服務廣播消息或向指定的微服務發送消息。Spring Cloud Stream 是一個消息驅動的微服務框架,它可以輕松地將消息通道與微服務進行集成。
(資料圖)
準備工作
首先,我們需要在 pom.xml 文件中添加以下依賴:
org.springframework.cloud spring-cloud-starter-bus-amqp org.springframework.cloud spring-cloud-stream-binder-rabbit 這些依賴將會引入 Spring Cloud Bus 和 Spring Cloud Stream 的相關庫,并且使用 RabbitMQ 作為消息代理。如果你想使用其他消息代理,可以根據實際需求進行修改。
創建消息通道
在這個例子中,我們將創建一個名為 myChannel 的消息通道,用于在微服務之間傳遞消息。在創建消息通道之前,我們需要在 application.yml 文件中添加以下配置:
spring: cloud: stream: bindings: myChannel: destination: myChannel這個配置將創建一個名為 myChannel 的消息通道,并將它綁定到 RabbitMQ 的 myChannel 隊列上。現在,我們可以在代碼中使用 @Input 和 @Output 注解來定義輸入和輸出消息通道了。
public interface MyChannel { String INPUT = "myInput"; String OUTPUT = "myOutput"; @Input(INPUT) SubscribableChannel input(); @Output(OUTPUT) MessageChannel output();}這個接口定義了一個名為 MyChannel 的消息通道,其中包括一個名為 myInput 的輸入消息通道和一個名為 myOutput 的輸出消息通道。
發布消息
在這個例子中,我們將創建一個名為 MyController 的控制器類,該類將發布一個名為 MyMessage 的消息到 myOutput 消息通道上。
@RestControllerpublic class MyController { @Autowired private MessageChannel output; @PostMapping("/send") public void sendMessage(@RequestBody MyMessage message) { output.send(MessageBuilder.withPayload(message).build()); }}這個控制器類注入了名為 output 的 MessageChannel,用于向 myOutput 消息通道發送消息。在 sendMessage 方法中,我們通過 MessageBuilder 創建一個名為 message 的 MyMessage 消息,然后通過 output.send 方法將這個消息發送到 myOutput 消息通道上。
處理消息
在這個例子中,我們將創建一個名為 MyListener 的監聽器類,該類將監聽 myInput 消息通道上的消息,并將消息打印到控制臺上。
@EnableBinding(MyChannel.class)public class MyListener { @StreamListener(MyChannel.INPUT) public void handleMessage(MyMessage message) { System.out.println("Received message: " + message); }}這個監聽器類使用 @EnableBinding 注解將 MyChannel 消息通道綁定到 Spring Cloud Stream 上。在 handleMessage 方法中,我們使用 @StreamListener 注解監聽 myInput 消息通道上的消息,當有消息到來時,Spring Cloud Stream 將自動將消息轉換為 MyMessage 類型,并將其傳遞給 handleMessage 方法進行處理。在這個例子中,我們只是簡單地將消息打印到控制臺上,你可以根據實際需求進行修改。
運行測試
現在,我們已經創建了消息通道、發布了消息和處理了消息,我們可以啟動應用程序并測試它了。首先,我們需要在終端窗口中啟動 RabbitMQ,執行以下命令:
cssCopy codedocker run -d --name rabbitmq -p 5672:5672 -p 15672:15672 rabbitmq:3-management這個命令將啟動一個名為 rabbitmq 的容器,并將其映射到本地主機的 5672 和 15672 端口上。現在,我們可以啟動應用程序并訪問 http://localhost:8080/send發送消息了。在控制臺中,你應該可以看到類似下面的輸出:
Received message: MyMessage{id=1, content="Hello, world!"}這表明消息已經成功傳遞到了 myInput 消息通道,并被 MyListener 監聽到并處理了。
關鍵詞:
[責任編輯:xwzkw]
相關閱讀
- (2023-04-24)天天訊息:使用 Spring Cloud Bus 和 Spring Cloud Stream 集成實現基于消息的事件驅動
- (2023-04-24)保立佳(301037):技術指標出現看漲信號-KDJ 低位金叉(04-24)|全球熱推薦
- (2023-04-24)用歌聲來溝通,這支視障患者組成的樂隊帶來與EYE“瞳”行音樂會 天天熱點評
- (2023-04-24)焦點!日產將電動e NV200轉變為無冰冰淇淋車
- (2023-04-24)焦點速讀:深圳市招雍置業擬進行增資 擬募集資金對應持股比例為不超30%
- (2023-04-24)湘西高新區召開文明城市創建工作推進會
- (2023-04-24)突然崩了!暴跌33% 30年不敗神話或破!傳媒互聯網板塊飆新高!-觀察
- (2023-04-24)布朗:言語無法表達羅威的貢獻 健康的他可能是聯盟最佳防守球員
- (2023-04-24)中消協發布“五一”消費提示:出行安全為先 綠色消費、明辨陷阱_每日消息
- (2023-04-24)"五一"在即,二次感染要來?專家:新冠正走向流感化 全球看熱訊
- (2023-04-24)火影忍者觀看順序圖 火影忍者觀看順序 環球滾動
- (2023-04-24)百安居圓滿舉辦工地開放日活動 打造透明工地 “鑒”證匠心品質
- (2023-04-24)【獨家】承認不正當關系 NBC環球CEO杰夫·謝爾引咎辭職
- (2023-04-24)4月24日白銀早評:已接近加息周期尾聲 白銀行情下行-每日資訊
- (2023-04-24)世界看熱訊:PS二/三檔5月34款游戲離庫:有開發商一次離庫12款
- (2023-04-24)環球新資訊:4月24日生意社液氨基準價為3050.00元/噸
- (2023-04-24)中國海軍航空兵某團長航時訓練見聞_滾動
- (2023-04-24)電腦連接電視以后沒有聲音_電腦連接電視沒有聲音怎么辦
- (2023-04-24)許繼電氣:4月21日融券凈賣出500股,連續3日累計凈賣出3.19萬股|每日視點
- (2023-04-24)報道:非全日制用工是臨時工嗎?不是!要簽合同,單位應繳工傷保險
- (2023-04-24)中國一冶海口美蘭機場過夜用房及配套項目竣工驗收|全球時快訊
- (2023-04-24)境外大學可在海南自由貿易港辦學 辦學學科限于理工農醫類
- (2023-04-24)山西省人才市場管理條例
- (2023-04-24)怎樣注銷支付寶賬號注銷_怎樣注銷支付寶賬號
- (2023-04-24)丹柯主題_丹柯
- (2023-04-24)王鳳文:?齊抓共管壓實責任 筑牢大慶安全生產防線
- (2023-04-24)長沙地鐵5號線什么時候開通 要聞
- (2023-04-24)河北省圖書館開啟4·23世界讀書日系列活動
- (2023-04-24)3hk電話卡_3hk|天天觀焦點
- (2023-04-24)焦點簡訊:范丞丞坐小卡車走紅毯 究竟為了什么?





