使用 Spring Cloud Bus 在微服務之間傳遞消息示例 全球熱資訊
(資料圖片)
下面是一個完整的示例,演示如何使用 Spring Cloud Bus 在微服務之間傳遞消息。該示例包含兩個微服務,一個是消息發(fā)送者,另一個是消息接收者。
首先,我們需要創(chuàng)建一個 Spring Boot 項目,并添加 Spring Cloud Bus 和 RabbitMQ 的依賴。在 pom.xml 文件中添加以下依賴:
org.springframework.cloud spring-cloud-starter-bus-amqp 2.2.1.RELEASE org.springframework.boot spring-boot-starter-web 2.2.1.RELEASE org.springframework.boot spring-boot-starter-amqp 2.2.1.RELEASE
在創(chuàng)建的項目中,我們定義了一個消息類型 MyMessage,該類型包含一個字符串類型的 content 屬性。
javaCopy codepublic class MyMessage implements Serializable { private static final long serialVersionUID = 1L; private String content; public MyMessage(String content) { this.content = content; } public String getContent() { return content; } public void setContent(String content) { this.content = content; }}
然后,我們創(chuàng)建了一個消息發(fā)送者,該發(fā)送者使用 Spring Cloud Bus 發(fā)送消息。
@RestControllerpublic class MyController { @Autowired private MessageSender messageSender; @PostMapping("/send") public void sendMessage(@RequestBody MyMessage message) { messageSender.sendMessage(message); }}@Servicepublic class MessageSender { private static final Logger LOGGER = LoggerFactory.getLogger(MessageSender.class); @Autowired private MessageChannel output; public void sendMessage(MyMessage message) { LOGGER.info("Sending message: {}", message.getContent()); output.send(MessageBuilder.withPayload(message).build()); }}@Servicepublic class MessageListener { private static final Logger LOGGER = LoggerFactory.getLogger(MessageListener.class); @StreamListener(target = Sink.INPUT, condition = "headers["type"]=="MyMessage"") public void handleMessage(MyMessage message) { LOGGER.info("Received message: {}", message.getContent()); }}
在這個例子中,我們創(chuàng)建了一個 MyController 類,該類定義了一個發(fā)送消息的 API 接口,接收一個 MyMessage 類型的參數(shù),將參數(shù)傳遞給 MessageSender 類的 sendMessage() 方法。
MessageSender 類定義了一個 sendMessage() 方法,該方法使用 Spring Cloud Stream 的 output 消息通道發(fā)送消息。
MessageListener 類定義了一個 handleMessage() 方法,該方法使用 @StreamListener 注解監(jiān)聽 Spring Cloud Stream 的 input 消息通道,并根據(jù)消息類型過濾消息。當有符合條件的消息到達時,handleMessage() 方法會被自動調(diào)用,處理接收到的消息。
在以上代碼中,我們使用了 @Autowired 注解自動注入了 MessageSender 和 MessageListener 類,這是 Spring Boot 自帶的依賴注入功能。
運行應用程序后,我們可以使用 Postman 工具或其他 HTTP 工具發(fā)送 HTTP POST 請求,將消息發(fā)送到消息發(fā)送者的 API 接口,如下所示:
POST http://localhost:8080/send HTTP/1.1Content-Type: application/json{ "content": "Hello, World!"}
當消息到達時,消息接收者會打印消息內(nèi)容,如下所示:
2023-04-19 09:24:47.836 INFO 29740 --- [afka-listener-1] com.example.demo.M
關(guān)鍵詞:
相關(guān)閱讀
-
使用 Spring Cloud Bus 在微服務之...
下面是一個完整的示例,演示如何使用SpringCloudBus在微服務之間傳... -
go的數(shù)據(jù)類型-其他數(shù)據(jù)類型-channel(二...
以下是一個使用Channel的示例程序,該程序創(chuàng)建了兩個Goroutine,并... -
興慶說節(jié)氣|“非遺之上·尋味生活”興...
興慶說節(jié)氣|“非遺之上·尋味生活”興慶區(qū)舉辦谷雨非遺飲食文化會 -
天天最資訊丨云溪區(qū)人社局:服務企業(yè)“...
云溪區(qū)人社局:服務企業(yè)“面對面”聽需問計解難題 -
Python面向?qū)ο缶幊?生成器
在Python中,生成器(Generator)是一種特殊的迭代器,可以通過函數(shù)... -
海南發(fā)展銀行倒閉的原因主要有哪些?海...
海南發(fā)展銀行倒閉的原因主要有哪些?海南發(fā)展銀行倒閉的原因有三個:... -
余額寶轉(zhuǎn)入轉(zhuǎn)出要手續(xù)費嗎?轉(zhuǎn)入余額寶...
余額寶轉(zhuǎn)入轉(zhuǎn)出要手續(xù)費嗎?不需要。從銀行卡中轉(zhuǎn)入到余額寶中的資金... -
余額寶轉(zhuǎn)入限額是多少?9萬元余額寶可以...
余額寶轉(zhuǎn)入限額是多少?余額寶中的全部貨幣基金都沒轉(zhuǎn)賬限額,但轉(zhuǎn)賬... -
其他應收款是什么意思?其他應收款借方...
其他應收款是什么意思?其他應收款是指企業(yè)除買入返售金融資產(chǎn)、應收... -
岳池站鐵路春運客運組織及策略研究_岳池站
1、廣安南動車票到成都東。2、岳池站可以上車。3、沒有問題。本文分... -
其他應收款包括哪些?其他應收款的款項...
其他應收款包括哪些?①應收的各種賠款、罰款。如因職工失職造成一定... -
退回的個稅手續(xù)費需要繳納增值稅嗎?個...
退回的個稅手續(xù)費需要繳納增值稅嗎?對于企業(yè)來說,即使再小金額的涉... -
個調(diào)稅是什么意思?退回的個稅手續(xù)費計...
個調(diào)稅是什么意思?個調(diào)稅的全稱是個人收入調(diào)節(jié)稅,是對在中國國內(nèi)有... -
世界百事通!官宣!北京車展將于明年4月...
4月21日,北京國際汽車展覽會秘書處發(fā)布公告宣布,2024(第十八屆)... -
網(wǎng)貸申請被拒有什么影響?網(wǎng)貸逾期征信...
網(wǎng)貸申請被拒有什么影響?1、影響個人綜合信用評分:用戶的征信報告... -
iHerb正推出春季煥新海外購活動,高能鉅...
春天來臨,iHerb又有鉅惠大放送!春季煥新海外購活動正火熱開展,只... -
養(yǎng)了三個月征信網(wǎng)貸還是被拒怎么辦?網(wǎng)...
養(yǎng)了三個月征信網(wǎng)貸還是被拒怎么辦?1、繼續(xù)養(yǎng)征信如果只是因為征信... -
退休人員小額貸款平臺有哪些?小額貸款...
退休人員小額貸款平臺有哪些?1、螞蟻借唄螞蟻消費金融旗下的小額貸... -
每日金選|燕京啤酒一季度凈利同比大增超...
戴維醫(yī)療公布2023年一季度報告,報告期公司實現(xiàn)營業(yè)收入1 58億元,... -
年報披露翌日,樂歌股份股價漲超6%
?樂居財經(jīng)吳文婷4月21日,截至發(fā)稿時,樂歌股份報19 53元,漲6 78...