【资料图】
下面是一个完整的示例,演示如何使用 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在微服务之间传递消息。该示例包含两个微服务,一个是消息发送者,另一个是消息接收者。2023-04-20 -
天天关注:藏不住啦!北科大文创雪糕来啦!
气温渐升,夏日将至!校庆进行时北科大专属文创雪糕来啦!四款造型,不同口味供同学们品尝挑选快来pick你中意的那一支吧“求实鼎新”雪糕榛仁2023-04-20 -
上海市经济和信息化委:未来三年上海将建设200家智能工厂 环球播资讯
4月20日,在2023上海车展现场,“百场万企,共话智能”2023汽车产业高质量创新发展论坛同步举行。上海市经济和信息化2023-04-20 -
三管齐下解决塑料污染危机:政策护航 技术回收 开发新品 全球快报
【三管齐下解决塑料污染危机】世界经济合作与发展组织(OECD)的数据显示,2019年,全球生产了3 53亿吨塑料废物,超2023-04-20 -
要闻:国家统计局:高等教育女生占比持续超过半数 2021年女研究生占比提高至51.5%
中国网财经4月20日讯4月20日,国家统计局发布2021年《中国妇女发展纲要(2021—2030年)》统计监测报告。报告显示,高等教育女生占比持续超过半2023-04-20 -
林肯航海家:从黄晓明代言微电影看科技与舒适的完美结合 世界速看
林肯航海家(参数|询价)的微电影广告以黄晓明代言的形式在网络上掀起了一场热议。然而,除了极具情感的广告,林肯航海家本身也是一款备受关注的2023-04-20 -
短讯!河南银保监局出台乡村振兴金融服务工作文件,围绕种业振兴等领域增加金融资源供给
为贯彻落实党中央、国务院关于建设农业强国的总体部署,按照银保监会工作要求,河南局结合农业大省实际,制定印发2023年乡村2023-04-20 -
【天天快播报】最高奖补200万元 郑州拟出台新策支持双创孵化载体建设
【大河财立方消息】4月19日,郑州市科学技术局就《支持创新创业孵化载体高质量发展实施细则(征求意见稿)》向社会公开征求意2023-04-20 -
车辆突然掉进河中,乐山交警奋勇救人 当前热点
乐山新闻网站是由市委宣传部主管的全民所有制事业单位,乐山地区唯一有新闻发布资格的大型综合门户网站,是乐山继乐山日报、乐山电视台、乐山2023-04-20 -
科达利:4月19日融券净卖出5448股,连续3日累计净卖出2.1万股_每日短讯
4月19日,科达利(002850)融资买入1113 14万元,融资偿还1519 93万元,融资净卖出406 79万元,融资余额1 32亿元。2023-04-20 -
两市主力资金净流出311.94亿元 医药生物行业净流出居首
沪指4月19日下跌0 68%,深成指下跌0 84%,创业板指下跌0 63%,沪深300指数下跌0 90%。可交易A股中,上涨的有1603只,占比31 13%,下跌的3377只2023-04-20 -
乐山一生鲜超市关门歇业,会员卡余额被清零,你充值了吗?
乐山新闻网站是由市委宣传部主管的全民所有制事业单位,乐山地区唯一有新闻发布资格的大型综合门户网站,是乐山继乐山日报、乐山电视台、乐山2023-04-20 -
为爱拼搏 圆梦嘉州|省残特奥会进行开幕式彩排[图]
乐山新闻网站是由市委宣传部主管的全民所有制事业单位,乐山地区唯一有新闻发布资格的大型综合门户网站,是乐山继乐山日报、乐山电视台、乐山2023-04-20