当前头条:使用 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 在微服务之间传递消息示例
- 环球快看点丨子湖有狗上取人头中取人心下取人足
- 天天信息:两部门联合发文:每局剧本娱乐活动结束后必须进行一次防火巡查
- 全球关注:中航长城计量测试天津有限公司招聘公告
- 热点!小熊电器:邹勇辉因个人原因辞去财务总监职务
- 环球百事通!水电大省“缺水”有解
- 世界微资讯!综合消息:苏丹武装冲突进入第四天 双方同意停火24小时
- 环球快资讯丨cad转换成mapgis_如何把cad图转换成jpg
- 热点聚焦:舍弗勒新品亮相上海车展,与智加科技达成量产合作
- 头条焦点:谷雨绵绵 芳菲满程
- 今日热闻!四川稻城县境内发生的森林火情已调集1100余人处置
- 世界看点:2023贵州铜仁市德江县事业单位招聘新增工作人员报名缴费人数公告(截止4月18日17:00)
- 世界速读:什么是焦虑症不真实感_什么是焦虑症
- 观热点:v家成员玩真心话大冒险_v家成员
- 全球即时:把握新机遇,发力新赛道!平安人寿安徽分公司召开2023年3A经理人招募培养计划发布会
- 速看:Snapchat Plus用户现在可以发布长达一周的故事
- 【世界播资讯】小说的三要素核心是什么_小说的三要素
- 世界热资讯!德称向乌克兰交付一套“爱国者”防空系统
- 世界热资讯!长峰医院现场:今日停诊、不办住院,院内仍有住院患者
- 天天简讯:成都海棠公寓保障性租赁住房有单间出租吗?
- 环球观察:北京长峰医院院长王某玲等12人被刑拘!
- 世界新动态:显卡温度测试怎么测?显卡温度长时间90度会烧吗?
- 世界今头条!十堰男子杀妻后东躲西藏31年 警方穷追不舍终将其擒获
- 天天热讯:一片红!市场情绪转强,农产品一马当先
- 当前热讯:惠誉警告:全球恐面临20年来最严重大米短缺
- 天天观察:恒立液压4月19日盘中涨幅达5%
- 当前动态:中科云网涨近5%,控股子公司拟50亿元投建N型高效电池项目
- 环球热议:工业富联股价跌停,公司回应:生产经营正常
- 每日热点:文旅观察丨汤显祖文化给浙江遂昌带来了什么?
- 世界观点:括约肌切开术
- 《高山清渠》播出过半 李健用真实形象诠释黄大发的奋斗轨迹
- 现实题材电视剧《分界线》8月1日播出 何冰张国强强手过招
- 花篮的花儿香!民族歌剧《唱响南泥湾》在保利剧院迎来首演
- 韩国电信公布未来五年非基础设施投资预算拨出12万亿韩元
- 冰墩墩设计者给北京四中学生回信:祝福可爱奋进的中国少
- 江苏南通发现1人检测结果呈阳性 系外地返通人员
- 湖南郴州报告2例香港返湘人员新冠肺炎确诊病例
- 广西百色疫情社区传播链基本阻断
- 广西新增1例本土确诊病例 本轮本土疫情累计报告确诊病例
- 葫芦岛市两医院不再收治非绥中地区患者 就医患者闭环管理
- 苏州14日新增本土确诊1例,无症状感染者3例 详情及轨迹公布
- 2021年北京空气质量创历史最优 首次全面达标