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

2023-04-22 14:26:14 来源:腾讯云


(相关资料图)

下面是一个完整的示例,演示如何使用 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

柚子皮的功效与作用降血糖_柚子皮的功效与作用

2023-04-22

中国17大名酒,3大酱酒之一的武陵,名气为何不及茅台和郎酒?

2023-04-22

每日观察!廉洁四川丨不敌“围猎”的公安局长

2023-04-22

一针引千线,架设湘台融合发展连心桥

2023-04-22

当前通讯!灞桥区第八幼儿园教师专业技能大赛

2023-04-22

向日葵和香槟玫瑰花放在一起代表什么_玫瑰花放在水里怎么养

2023-04-22

一年级上学期工具书_一年级上学期工作总结

2023-04-22

标致的首款SUV 标致4007的车系简介

2023-04-22

2023年4月21日 星期五 晴|每日快看

2023-04-22

业绩被苹果「砍伤」,700亿果链龙头:已充分反思、吸取教训-全球新动态

2023-04-22

超强的视觉震撼!小米智能网络液晶平板电视L70M5-4A。

2023-04-22

每日播报!擒蛇_关于擒蛇的介绍

2023-04-22

灵武市:劳动技能展风采,文明校园我先行

2023-04-22

新时代如何在全球讲好中国故事?外籍网络名人齐聚南京聊“中国缘”“山海情”

2023-04-22

【焦点热闻】大话西游经典台词大全_大话西游经典台词 我的意中人是一个绝世英雄后面的完整回答_360

2023-04-22

环球热推荐:机构:印度智能手机市场第一季度出货量史无前例同比下降20%

2023-04-22

广州招用就业困难人员社保补贴和员工制家政企业社保补贴能一起享受吗

2023-04-22

焦点快看:国家药监局:第三方平台要持续守法合规 采取多种措施规范药品网络销售市场秩序

2023-04-22

擦亮清廉政务“主色” 营造优质高效“本色”

2023-04-22

全球新动态:火龙果是凉性的吗_火龙果一天可以吃几个

2023-04-22

世界报道:阿泰尔盔甲几枚 阿泰尔盔甲

2023-04-22

A股又上热搜!往日“香饽饽”沦为“砸盘王”

2023-04-22

二手房指导价两年后,最后的“高地”正慢慢淡出 天天热闻

2023-04-22

排查维修!定兴县宏屹国际城故障电梯恢复运行

2023-04-22

义渠国是现在的哪个省_义渠国是现在的哪里

2023-04-22

一季度经济发展实现良好开局 将多措并举巩固经济向好势头

2023-04-22

当前观点:金石投资(00901.HK)2022年度亏损约3486万港元 核数师发出非标准报告

2023-04-22

2023福建三明市考试录用公务员体检的通知(一)-世界今头条

2023-04-22

环球最资讯丨昆明种植牙集采落地 单颗总费用降50%

2023-04-22

Copyright ©  2015-2022 热讯频道网版权所有  备案号:豫ICP备20005723号-6   联系邮箱:29 59 11 57 8@qq.com