人妻~夫の上司犯感との,公么大龟弄得我好舒服秀婷视频,国产成人久久av免费,亚洲精品一区久久久久久

您的位置:首頁 > 要聞 >

天天訊息:使用 Spring Cloud Bus 和 Spring Cloud Stream 集成實(shí)現(xiàn)基于消息的事件驅(qū)動(dòng)

2023-04-24 15:09:43 來源:騰訊云

基于消息的事件驅(qū)動(dòng)是一種常見的微服務(wù)架構(gòu)設(shè)計(jì)模式,它將不同的微服務(wù)之間通過消息進(jìn)行通信,實(shí)現(xiàn)松耦合、高可伸縮性和高可靠性。在這種架構(gòu)下,每個(gè)微服務(wù)都是獨(dú)立的,它們可以在消息傳遞的過程中進(jìn)行異步操作,這使得整個(gè)系統(tǒng)的性能得到了很大的提升。

在 Spring Cloud 中,我們可以使用 Spring Cloud Bus 和 Spring Cloud Stream 集成來實(shí)現(xiàn)基于消息的事件驅(qū)動(dòng)。Spring Cloud Bus 是一個(gè)消息總線,它可以在微服務(wù)之間傳遞消息,可以將所有微服務(wù)視為一個(gè)整體,向所有微服務(wù)廣播消息或向指定的微服務(wù)發(fā)送消息。Spring Cloud Stream 是一個(gè)消息驅(qū)動(dòng)的微服務(wù)框架,它可以輕松地將消息通道與微服務(wù)進(jìn)行集成。


(資料圖)

準(zhǔn)備工作

首先,我們需要在 pom.xml 文件中添加以下依賴:

    org.springframework.cloud    spring-cloud-starter-bus-amqp    org.springframework.cloud    spring-cloud-stream-binder-rabbit

這些依賴將會(huì)引入 Spring Cloud Bus 和 Spring Cloud Stream 的相關(guān)庫,并且使用 RabbitMQ 作為消息代理。如果你想使用其他消息代理,可以根據(jù)實(shí)際需求進(jìn)行修改。

創(chuàng)建消息通道

在這個(gè)例子中,我們將創(chuàng)建一個(gè)名為 myChannel 的消息通道,用于在微服務(wù)之間傳遞消息。在創(chuàng)建消息通道之前,我們需要在 application.yml 文件中添加以下配置:

spring:  cloud:    stream:      bindings:        myChannel:          destination: myChannel

這個(gè)配置將創(chuàng)建一個(gè)名為 myChannel 的消息通道,并將它綁定到 RabbitMQ 的 myChannel 隊(duì)列上?,F(xiàn)在,我們可以在代碼中使用 @Input 和 @Output 注解來定義輸入和輸出消息通道了。

public interface MyChannel {    String INPUT = "myInput";    String OUTPUT = "myOutput";    @Input(INPUT)    SubscribableChannel input();    @Output(OUTPUT)    MessageChannel output();}

這個(gè)接口定義了一個(gè)名為 MyChannel 的消息通道,其中包括一個(gè)名為 myInput 的輸入消息通道和一個(gè)名為 myOutput 的輸出消息通道。

發(fā)布消息

在這個(gè)例子中,我們將創(chuàng)建一個(gè)名為 MyController 的控制器類,該類將發(fā)布一個(gè)名為 MyMessage 的消息到 myOutput 消息通道上。

@RestControllerpublic class MyController {    @Autowired    private MessageChannel output;    @PostMapping("/send")    public void sendMessage(@RequestBody MyMessage message) {        output.send(MessageBuilder.withPayload(message).build());    }}

這個(gè)控制器類注入了名為 output 的 MessageChannel,用于向 myOutput 消息通道發(fā)送消息。在 sendMessage 方法中,我們通過 MessageBuilder 創(chuàng)建一個(gè)名為 message 的 MyMessage 消息,然后通過 output.send 方法將這個(gè)消息發(fā)送到 myOutput 消息通道上。

處理消息

在這個(gè)例子中,我們將創(chuàng)建一個(gè)名為 MyListener 的監(jiān)聽器類,該類將監(jiān)聽 myInput 消息通道上的消息,并將消息打印到控制臺(tái)上。

@EnableBinding(MyChannel.class)public class MyListener {    @StreamListener(MyChannel.INPUT)    public void handleMessage(MyMessage message) {        System.out.println("Received message: " + message);    }}

這個(gè)監(jiān)聽器類使用 @EnableBinding 注解將 MyChannel 消息通道綁定到 Spring Cloud Stream 上。在 handleMessage 方法中,我們使用 @StreamListener 注解監(jiān)聽 myInput 消息通道上的消息,當(dāng)有消息到來時(shí),Spring Cloud Stream 將自動(dòng)將消息轉(zhuǎn)換為 MyMessage 類型,并將其傳遞給 handleMessage 方法進(jìn)行處理。在這個(gè)例子中,我們只是簡(jiǎn)單地將消息打印到控制臺(tái)上,你可以根據(jù)實(shí)際需求進(jìn)行修改。

運(yùn)行測(cè)試

現(xiàn)在,我們已經(jīng)創(chuàng)建了消息通道、發(fā)布了消息和處理了消息,我們可以啟動(dòng)應(yīng)用程序并測(cè)試它了。首先,我們需要在終端窗口中啟動(dòng) RabbitMQ,執(zhí)行以下命令:

cssCopy codedocker run -d --name rabbitmq -p 5672:5672 -p 15672:15672 rabbitmq:3-management

這個(gè)命令將啟動(dòng)一個(gè)名為 rabbitmq 的容器,并將其映射到本地主機(jī)的 5672 和 15672 端口上?,F(xiàn)在,我們可以啟動(dòng)應(yīng)用程序并訪問 http://localhost:8080/send發(fā)送消息了。在控制臺(tái)中,你應(yīng)該可以看到類似下面的輸出:

Received message: MyMessage{id=1, content="Hello, world!"}

這表明消息已經(jīng)成功傳遞到了 myInput 消息通道,并被 MyListener 監(jiān)聽到并處理了。

關(guān)鍵詞:

[責(zé)任編輯:xwzkw]

相關(guān)閱讀

厨房的春潮a片| 乱中年女人伦av三区| 国产gv天堂亚洲国产gv刚刚碰| 国产spa盗摄xo在线观看| 日本片在线看的免费网站| 免费观看视频的app| 亚洲av乱码一区二区三区按摩 | 成品w灬源码伊旬园大象2023| 亚洲麻豆AV无码成人片在线观看| 国产AV成人一区二区三区| 在线亚洲人成电影网站色www| 拍摄av现场失控高潮数次| 久久久久精品国产三级| 日b视频| 大炕上的肉体交换农村乱睡| 内衣办公室1~3卷翻译樱花| 国产精品久久久久9999吃药| 日本乱偷中文字幕| 在电影院里拨开内裤挺进| 性xxxxfreexxxxxvideo| 欧美激情视频| 国产乱自产黄a片在线观看| 最近2019年免费中文字幕电影| gay翘屁嫩男爽到失禁| 小雪又胀又麻又酸又痒| 日本做床爱全过程激烈视频| 表妺好紧竟然流水了在线观看| 肉欲娇宠(h)皇帝篇31| 亚洲精品又粗又大又爽a片| 人妻在卧室被老板疯狂进入| 极品少妇XXOO无码播放| А√天堂WWW在线А√天堂视频| 小雪第一次尝到又大又粗| 舌头伸进去添的我好爽| 曰本性l交片免费看| 成人女人爽到高潮的a片| 欧美日韩国产成人高清视频 | 亚洲香蕉中文日韩v日本国产| 日韩精品一区二区av在线观看| ass大胆孕妇分娩pics| 亚洲无线卡一卡二|