基于消息的事件驅(qū)動是一種常見的微服務(wù)架構(gòu)設(shè)計模式,它將不同的微服務(wù)之間通過消息進(jìn)行通信,實現(xiàn)松耦合、高可伸縮性和高可靠性。在這種架構(gòu)下,每個微服務(wù)都是獨立的,它們可以在消息傳遞的過程中進(jìn)行異步操作,這使得整個系統(tǒng)的性能得到了很大的提升。
在 Spring Cloud 中,我們可以使用 Spring Cloud Bus 和 Spring Cloud Stream 集成來實現(xiàn)基于消息的事件驅(qū)動。Spring Cloud Bus 是一個消息總線,它可以在微服務(wù)之間傳遞消息,可以將所有微服務(wù)視為一個整體,向所有微服務(wù)廣播消息或向指定的微服務(wù)發(fā)送消息。Spring Cloud Stream 是一個消息驅(qū)動的微服務(wù)框架,它可以輕松地將消息通道與微服務(wù)進(jìn)行集成。
(資料圖)
首先,我們需要在 pom.xml 文件中添加以下依賴:
org.springframework.cloud spring-cloud-starter-bus-amqp org.springframework.cloud spring-cloud-stream-binder-rabbit
這些依賴將會引入 Spring Cloud Bus 和 Spring Cloud Stream 的相關(guān)庫,并且使用 RabbitMQ 作為消息代理。如果你想使用其他消息代理,可以根據(jù)實際需求進(jìn)行修改。
在這個例子中,我們將創(chuàng)建一個名為 myChannel 的消息通道,用于在微服務(wù)之間傳遞消息。在創(chuàng)建消息通道之前,我們需要在 application.yml 文件中添加以下配置:
spring: cloud: stream: bindings: myChannel: destination: myChannel
這個配置將創(chuàng)建一個名為 myChannel 的消息通道,并將它綁定到 RabbitMQ 的 myChannel 隊列上?,F(xiàn)在,我們可以在代碼中使用 @Input 和 @Output 注解來定義輸入和輸出消息通道了。
public interface MyChannel { String INPUT = "myInput"; String OUTPUT = "myOutput"; @Input(INPUT) SubscribableChannel input(); @Output(OUTPUT) MessageChannel output();}
這個接口定義了一個名為 MyChannel 的消息通道,其中包括一個名為 myInput 的輸入消息通道和一個名為 myOutput 的輸出消息通道。
在這個例子中,我們將創(chuàng)建一個名為 MyController 的控制器類,該類將發(fā)布一個名為 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 消息通道發(fā)送消息。在 sendMessage 方法中,我們通過 MessageBuilder 創(chuàng)建一個名為 message 的 MyMessage 消息,然后通過 output.send 方法將這個消息發(fā)送到 myOutput 消息通道上。
在這個例子中,我們將創(chuàng)建一個名為 MyListener 的監(jiān)聽器類,該類將監(jiān)聽 myInput 消息通道上的消息,并將消息打印到控制臺上。
@EnableBinding(MyChannel.class)public class MyListener { @StreamListener(MyChannel.INPUT) public void handleMessage(MyMessage message) { System.out.println("Received message: " + message); }}
這個監(jiān)聽器類使用 @EnableBinding 注解將 MyChannel 消息通道綁定到 Spring Cloud Stream 上。在 handleMessage 方法中,我們使用 @StreamListener 注解監(jiān)聽 myInput 消息通道上的消息,當(dāng)有消息到來時,Spring Cloud Stream 將自動將消息轉(zhuǎn)換為 MyMessage 類型,并將其傳遞給 handleMessage 方法進(jìn)行處理。在這個例子中,我們只是簡單地將消息打印到控制臺上,你可以根據(jù)實際需求進(jìn)行修改。
現(xiàn)在,我們已經(jīng)創(chuàng)建了消息通道、發(fā)布了消息和處理了消息,我們可以啟動應(yīng)用程序并測試它了。首先,我們需要在終端窗口中啟動 RabbitMQ,執(zhí)行以下命令:
cssCopy codedocker run -d --name rabbitmq -p 5672:5672 -p 15672:15672 rabbitmq:3-management
這個命令將啟動一個名為 rabbitmq 的容器,并將其映射到本地主機(jī)的 5672 和 15672 端口上?,F(xiàn)在,我們可以啟動應(yīng)用程序并訪問 http://localhost:8080/send發(fā)送消息了。在控制臺中,你應(yīng)該可以看到類似下面的輸出:
Received message: MyMessage{id=1, content="Hello, world!"}
這表明消息已經(jīng)成功傳遞到了 myInput 消息通道,并被 MyListener 監(jiān)聽到并處理了。
關(guān)鍵詞:
免責(zé)聲明:本網(wǎng)站所有信息,并不代表本站贊同其觀點和對其真實性負(fù)責(zé),投資者據(jù)此操作,風(fēng)險請自擔(dān)。
基于消息的事件驅(qū)動是一種常見的微服務(wù)架構(gòu)設(shè)計模式,它將不同的微服務(wù)之間通過消息進(jìn)行通信,實現(xiàn)松耦合、高可伸縮性和高可靠性。在這...
地板有哪幾種材質(zhì)?1、實木地板:它的木材特點是當(dāng)氣候干燥時,木材里面水分釋出,而氣候潮濕,木材又會吸附空氣里的水分。木地板經(jīng)過吸收及
【滬電股份今日漲停二機(jī)構(gòu)凈買入1 77億元】滬電股份今日漲停,成交額35 40億元,換手率7 34%,盤后龍虎榜數(shù)據(jù)顯示,深股通專用席位買入2 15億
遼寧證券業(yè)協(xié)會、轄區(qū)證券期貨經(jīng)營機(jī)構(gòu)、投資咨詢公司、基金機(jī)構(gòu)負(fù)責(zé)人等200余人線上線下參會
電動門有哪些類型1、按啟閉形式分電動門有不少啟動方式,有推拉、平開、重疊、折疊、弧形、旋轉(zhuǎn)等等方式,電動推拉門又可細(xì)分為單開門、雙
【中國結(jié)算公司:統(tǒng)一賬戶平臺、身份信息核查系統(tǒng)于4月22日全天暫停對外服務(wù)】據(jù)中國證券登記結(jié)算有限責(zé)任公司官網(wǎng)公告,“因技術(shù)系統(tǒng)測...
強(qiáng)冷空氣影響中國大部北方部分地區(qū)降溫超20℃,主流媒體,山西門戶。山西新聞網(wǎng)是經(jīng)國務(wù)院新聞辦審核批準(zhǔn),由山西日報報業(yè)集團(tuán)主管、主辦的山西
【藍(lán)色光標(biāo)今日20cm漲停二機(jī)構(gòu)凈買入2 97億元】藍(lán)色光標(biāo)今日20cm漲停,成交額61 14億元,換手率26 39%,盤后龍虎榜數(shù)據(jù)顯示,深股通專用席位買
國家消防救援局:堅決防范遏制重特大火災(zāi)事故,主流媒體,山西門戶。山西新聞網(wǎng)是經(jīng)國務(wù)院新聞辦審核批準(zhǔn),由山西日報報業(yè)集團(tuán)主管、主辦...
凡人微光|當(dāng)傳統(tǒng)文化遇上“后浪”,主流媒體,山西門戶。山西新聞網(wǎng)是經(jīng)國務(wù)院新聞辦審核批準(zhǔn),由山西日報報業(yè)集團(tuán)主管、主辦的山西省重...
行情回顧:今日黑色系大幅回落。熱卷跌51元收3973,螺紋鋼跌26元收3914,焦炭跌82 5元收2312,鐵礦石跌20 5元收761 5?,F(xiàn)貨市場:今日4 75m
新華全媒+|一季度經(jīng)濟(jì)形勢怎么看?如何擴(kuò)內(nèi)需、強(qiáng)信心?——國家發(fā)展改革委新聞發(fā)布會回應(yīng)當(dāng)前經(jīng)濟(jì)熱點,主流媒體,山西門戶。山西新聞網(wǎng)...
全國已春播糧食面積超1 6億畝進(jìn)度近兩成,主流媒體,山西門戶。山西新聞網(wǎng)是經(jīng)國務(wù)院新聞辦審核批準(zhǔn),由山西日報報業(yè)集團(tuán)主管、主辦的山...
電動門遙控器配對教程是怎樣的?1、清碼:同時按住鎖定鍵和向下鍵,可以看到指示燈在不停跳動。只需按住遙控器上的按鈕,您可以看到指示燈亮
記者從福建省交通運輸廳獲悉,一季度,福建省公路水路交通投資累計完成289億元,超序時進(jìn)度3 9個百分點,累計開工21個重大交通項目。
建筑模板有什么優(yōu)勢1、因為這種建筑模板的質(zhì)量比較輕,可以隨意鉆或者打釘、鋸,能夠組成不同的造型,適用于建筑支模需求。2、另外它的表面
建筑模板的尺寸規(guī)格有哪些?1、建筑模板的尺寸規(guī)格還是比較多的,而在生活中它的使用范圍非常廣泛。規(guī)格有兩種,一種就是1 83×0 92米
鋼絲網(wǎng)片有什么用途1、鋼絲網(wǎng)片可以用做地暖的加熱網(wǎng)片,鋪設(shè)在地面上,能夠達(dá)到地暖很好的保暖效果。在使用鋼絲網(wǎng)片時,一般都會采用整體
鋼絲網(wǎng)片的規(guī)格型號有哪些?孔徑為2厘米,5厘米,10厘米和15厘米等,外觀尺寸為1 2x3厘米,1x3厘米。鋼絲網(wǎng)片是由優(yōu)質(zhì)的低碳鋼絲按照十字形
家用電器短路起火用什么滅火器?可以用干粉滅火器。遭遇到電器短路引發(fā)的火災(zāi)時,不可以帶電滅火,也不能使用水基滅火跟泡沫滅火器進(jìn)行滅火
地板有哪幾種材質(zhì)?1、實木地板:它的木材特點是當(dāng)氣候干燥時,木材里面水分釋出,而氣候潮濕,木材又會吸附...
電動門有哪些類型1、按啟閉形式分電動門有不少啟動方式,有推拉、平開、重疊、折疊、弧形、旋轉(zhuǎn)等等方式,電...
使用砂漿噴涂機(jī)要注意什么?1、在操作砂漿噴涂機(jī)的時候,需要盡可能的減少彎管的存在,以免影響到砂漿的正常...