使用 Spring Cloud Bus 在微服务之间传递消息示例 全球热资讯
(资料图片)
下面是一个完整的示例,演示如何使用 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 在微服务之...
下面是一个完整的示例,演示如何使用SpringCloudBus在微服务之间传... -
go的数据类型-其他数据类型-channel(二...
以下是一个使用Channel的示例程序,该程序创建了两个Goroutine,并... -
兴庆说节气|“非遗之上·寻味生活”兴...
兴庆说节气|“非遗之上·寻味生活”兴庆区举办谷雨非遗饮食文化会 -
天天最资讯丨云溪区人社局:服务企业“...
云溪区人社局:服务企业“面对面”听需问计解难题 -
Python面向对象编程-生成器
在Python中,生成器(Generator)是一种特殊的迭代器,可以通过函数... -
海南发展银行倒闭的原因主要有哪些?海...
海南发展银行倒闭的原因主要有哪些?海南发展银行倒闭的原因有三个:... -
余额宝转入转出要手续费吗?转入余额宝...
余额宝转入转出要手续费吗?不需要。从银行卡中转入到余额宝中的资金... -
余额宝转入限额是多少?9万元余额宝可以...
余额宝转入限额是多少?余额宝中的全部货币基金都没转账限额,但转账... -
其他应收款是什么意思?其他应收款借方...
其他应收款是什么意思?其他应收款是指企业除买入返售金融资产、应收... -
岳池站铁路春运客运组织及策略研究_岳池站
1、广安南动车票到成都东。2、岳池站可以上车。3、没有问题。本文分... -
其他应收款包括哪些?其他应收款的款项...
其他应收款包括哪些?①应收的各种赔款、罚款。如因职工失职造成一定... -
退回的个税手续费需要缴纳增值税吗?个...
退回的个税手续费需要缴纳增值税吗?对于企业来说,即使再小金额的涉... -
个调税是什么意思?退回的个税手续费计...
个调税是什么意思?个调税的全称是个人收入调节税,是对在中国国内有... -
世界百事通!官宣!北京车展将于明年4月...
4月21日,北京国际汽车展览会秘书处发布公告宣布,2024(第十八届)... -
网贷申请被拒有什么影响?网贷逾期征信...
网贷申请被拒有什么影响?1、影响个人综合信用评分:用户的征信报告... -
iHerb正推出春季焕新海外购活动,高能钜...
春天来临,iHerb又有钜惠大放送!春季焕新海外购活动正火热开展,只... -
养了三个月征信网贷还是被拒怎么办?网...
养了三个月征信网贷还是被拒怎么办?1、继续养征信如果只是因为征信... -
退休人员小额贷款平台有哪些?小额贷款...
退休人员小额贷款平台有哪些?1、蚂蚁借呗蚂蚁消费金融旗下的小额贷... -
每日金选|燕京啤酒一季度净利同比大增超...
戴维医疗公布2023年一季度报告,报告期公司实现营业收入1 58亿元,... -
年报披露翌日,乐歌股份股价涨超6%
?乐居财经吴文婷4月21日,截至发稿时,乐歌股份报19 53元,涨6 78...