使用 Spring Cloud Bus 在微服务之间传递消息示例

2023-04-22 10:33:31 来源:腾讯云


(相关资料图)

下面是一个完整的示例,演示如何使用 Spring Cloud Bus 在微服务之间传递消息。该示例包含两个微服务,一个是消息发送者,另一个是消息接收者。

首先,我们需要创建一个 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

在创建的项目中,我们定义了一个消息类型 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;    }}

然后,我们创建了一个消息发送者,该发送者使用 Spring Cloud Bus 发送消息。

@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());    }}

在这个例子中,我们创建了一个 MyController 类,该类定义了一个发送消息的 API 接口,接收一个 MyMessage 类型的参数,将参数传递给 MessageSender 类的 sendMessage() 方法。

MessageSender 类定义了一个 sendMessage() 方法,该方法使用 Spring Cloud Stream 的 output 消息通道发送消息。

MessageListener 类定义了一个 handleMessage() 方法,该方法使用 @StreamListener 注解监听 Spring Cloud Stream 的 input 消息通道,并根据消息类型过滤消息。当有符合条件的消息到达时,handleMessage() 方法会被自动调用,处理接收到的消息。

在以上代码中,我们使用了 @Autowired 注解自动注入了 MessageSender 和 MessageListener 类,这是 Spring Boot 自带的依赖注入功能。

运行应用程序后,我们可以使用 Postman 工具或其他 HTTP 工具发送 HTTP POST 请求,将消息发送到消息发送者的 API 接口,如下所示:

POST http://localhost:8080/send HTTP/1.1Content-Type: application/json{    "content": "Hello, World!"}

当消息到达时,消息接收者会打印消息内容,如下所示:

2023-04-19 09:24:47.836  INFO 29740 --- [afka-listener-1] com.example.demo.M
标签:

使用 Spring Cloud Bus 在微服务之间传递消息示例

2023-04-22

【天天聚看点】烽火通信:2022年净利润同比增长40.6% 拟10股派1.1元

2023-04-22

当前速讯:保佑!国乒名将成亲,击败张继科和许昕,拿下单打全国冠军

2023-04-22

环球热文:人民网内蒙古分公司走进内蒙古电力集团调研座谈

2023-04-22

宝马MINI再次致歉 市值一夜蒸发183亿元

2023-04-22

中际联合:4月21日融资买入513.92万元,融资融券余额4986.42万元_天天通讯

2023-04-22

日本中型航空公司AIR DO和Solaseed Air经营合并,将维持现有航空品牌

2023-04-22

索尼、任天堂携手诸厂商 赞助TGS2023独立游戏项目

2023-04-22

戴口罩勒耳朵怎么办?

2023-04-22

与其减少对华贸易,不如减少美元贸易_环球新资讯

2023-04-22

报道:讲述世界城市日故事 她为上海推广“城市名片”

2023-04-22

今日聚焦!2023年中国网络媒体论坛“中国叙事•构建国际传播新范式”平行论坛在南京举行

2023-04-22

冬天怎样敷面膜才能更好的保养肌肤?

2023-04-22

环球讯息:郫县豆瓣酱能做汤吗_郫县豆瓣酱能做什么菜

2023-04-22

直播间“贩卖”小哥哥:有人看没人买

2023-04-22

商务部电子商务司负责人介绍2023年一季度网络零售市场发展情况 看点

2023-04-22

美股异动 | 传3B家居(BBBY.US)将于周末申请破产 股价涨超16%

2023-04-22

翔鹭钨业(002842.SZ)2022年度净亏损4126.25万元、同比盈转亏

2023-04-22

新浪微博电脑版官方下载_新浪微博电脑版-全球观热点

2023-04-22

李泰民金在中发文悼念文彬:希望你在那里幸福

2023-04-22

当前滚动:斯泰伦博斯_关于斯泰伦博斯简介

2023-04-22

比亚迪王传福乘地铁参加车展照片刷屏,一直对轨道交通有兴趣|当前速读

2023-04-22

4月21日河南宝鑫聚合氯化铝价格平稳 当前动态

2023-04-22

环球观察:深度分析|上汽大众ID.4 X,品质感与智能水准的提升!

2023-04-22

鲁商集团10亿元私募项目状态更新为“已反馈”|全球热点

2023-04-22

今日热门!925除以5的竖式计算过程_925除以5的竖式

2023-04-22

全军武器装备采购信息网第三批异地查询点正式开通运行 今日要闻

2023-04-22

东方财富:2023年第一季度净利润约20.29亿元 同比下降6.54%

2023-04-22

美银行业:美国经济疲软 消费者开始拖欠信贷还款-世界热讯

2023-04-22

个人装修合同范本下载(个人装修合同范本)

2023-04-22

Copyright ©  2015-2023 非洲频道网版权所有  备案号:沪ICP备2022005074号-8   联系邮箱:58 55 97 3@qq.com