2021年9月29日 星期三

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

时间:2023-04-22 10:38:37来源 : 腾讯云


(资料图片)

下面是一个完整的示例,演示如何使用 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 在微服务之间传递消息示例

前三场国王三分命中率27.6%!科尔:不会假装说完全因为防守到位

【世界新视野】2023年中国网络媒体论坛“中国叙事·构建国际传播新范式”平行论坛在南京举行

关于猫的作文500字

喜报!中国车企销量首次超越美国车企 拿下世界第三_焦点短讯

新时代 新征程 新伟业丨“顶梁柱”缘何坚挺强劲 ——一季度我省工业经济稳步增长情况解读

全球热点!2023年河南中招考试将于6月26日~28日举行

恒指夜期收盘(4.22)︱恒生指数夜期(4月)收报20009点 低水67点|世界新消息

北方将现大范围雨雪 山西陕西局地或冷到破纪录|世界微资讯

中国驻苏丹使馆发布安全提示-天天短讯

全球最新:甲钴胺片能和硝苯地平缓释片一起服用_硝苯地平缓释片怎么服用 硝苯地平缓释片的使用方法是什么

速讯:地里种香菜方法_香菜的种植方法介绍

观天下!大连旅行社哪家好一点_大连旅行社哪家好

新资讯:三峡大学统一身份认证中心(三峡大学公共门户)

2023广州白云消费券在哪里领?-百事通

今日最新!时代变了,广州队中甲报名名单:共31人,其中U21球员16人

环球视讯!84消毒液泡污用热水还是冷水好?

2023台州草地音乐节四月最全节目单_天天简讯

存储开源,风雨飘摇下“披着羊皮的狼”?|环球快播

热点!c盘根目录是哪个文件夹_c盘根目录

天天动态:犀牛看市0421:上证指数跌近2%险破3300点 新冠药板块异动

焦点速读:中央纪委国家监委通报2023年第一季度全国纪检监察机关监督检查、审查调查情况

造3好号和密码真的 造3好号|天天短讯

【全球播资讯】广州白云区幼儿园新生入学需要什么材料2023

中景股份2022年净利75.74万同比下滑11.24% 景观设计项目减少

全球连线|“沙漠之湖”持续扩容折射“中国沙乡”生态向好

【天天快播报】归结原理证明定理步骤_归结近义词

GAN卷土重来:10亿参数的GigaGAN效果堪比扩散模型 看点

中国队包揽WTT冠军赛澳门站女单四强 全球速递

厄尔尼诺归来?今年或成“最热年”→

Back to Top