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

2023-04-22 23:27:01 来源:腾讯云


(相关资料图)

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

天天要闻:女生回应失业摆摊一天卖5块:摆摊是短期选择

2023-04-22

9.9元的咖啡,谁能玩得更久?

2023-04-22

世界滚动:世体:姆巴佩希望梅西留在巴黎,很欣赏梅西让进攻变得更容易?

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-04-22

什么是快闪书店_什么是快闪

2023-04-22

有亮点但不多?全新雅阁e:PHEV亮相上海车展

2023-04-22

全球播报:建筑类甲级资质_建筑甲级资质业务范围 当前快播

2023-04-22

最新房地产开发成本测算表_房地产成本控制方法-环球百事通

2023-04-22

现场直击!登陆全过程演练

2023-04-22

当前报道:独家丨对抗抖音,美团将完成新一轮组织调整

2023-04-22

全球热点!获利挂单和触发挂单有什么区别_获利挂单是什么意思

2023-04-22

最新消息:湖北省武汉市2023-04-22 12:21发布雷电黄色预警

2023-04-22

兰碧诗能让眼皮不松弛吗 兰碧诗

2023-04-22

精子气味栗花_精子味道是什么气味

2023-04-22

意外!刘殿座失误葬送三镇好局,未来或因此加速世俱杯王牌加盟

2023-04-22

热消息:以服务升级助力销量提升,北汽鹏龙探索销售新道路

2023-04-22

环球今头条!家里贴什么样的财神爷最好 挂财神画的讲究有哪些

2023-04-22

热头条丨民航运输显著恢复

2023-04-22

环球最资讯丨立春之后就是春天吗?

2023-04-22

倒计时2天 | 第六届广东社交电商大会暨全域电商资源对接会-当前消息

2023-04-22

刚入职场的空竟被病娇前辈疯狂追求8

2023-04-22

【全球新要闻】环游世界的梦想_关于环游世界的梦想介绍

2023-04-22

世界热议:世界地球日丨听,首张野生动植物群星唱片来了

2023-04-22

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