使用 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 在微服务之间传递消息示例
- 【全球时快讯】一起去玩!碧海金沙开园啦
- 天天消息!来淄博吃烧烤,“酒桌三件套”要记牢,不懂可惜了,建议收藏
- 分享!古诗讲述了中国人的哲学-环球滚动
- 大田县气象台发布雷电黄色预警【Ⅲ级/较重】【2023-04-23】_全球独家
- 经济日报金观平:有效投资为高质量发展添动力
- 《满庭芳:宋上繁华》制作组专访:大宋小城,以史为本 天天日报
- 2019年伏天多少天结束_2018年伏天时间表
- 天天速讯:铁军风采|张小伟:用无悔青春捍卫绿水青山 努力当好湟水守护人
- 筑牢安全防线,苏州太平街道开展安全生产培训会 独家
- 前沿资讯!罗马诺:切尔西接近免签本菲卡18岁天才边锋莫雷拉
- 中国是全球经济增长的重要引擎
- 中南大学建筑与艺术学院保研政策_中南大学建筑与艺术学院
- 关于赚钱的随笔
- 中国电信启动PON设备集采,涉及10G-EPON、XG-PON、XGS-PON三种设备|当前简讯
- 直播电商,老外为什么学不会?
- pc镜片是树脂材料吗_pc镜片是什么材质 天天播资讯
- 互动| 盛屯矿业:受生产成本上升及钴金属价格下跌的叠加影响,公司2022年度业绩出现大幅下滑_环球新资讯
- 今日看点:小汤山名字由来_原来是这么来的
- 全球热点评!快船vs太阳G3,平行宇宙里的一场湘北战山王
- 【世界播资讯】原振侠电视剧主题曲_原振侠电视剧
- 看热讯:统编教材_关于统编教材介绍
- 焦点快播:2023中国网络媒体论坛在江苏南京举行
- 太原敦化坊街道成立全民读书会
- 相约安徽·向春而行|奖励50万!芜湖“夜经济”扶持政策重磅发布
- 环球实时:改良加藤法
- 年报观察丨靠代理业务“躺赢”的智飞生物,还能走多久?|世界视讯
- 上海海昌海洋公园2头江豚离世!“饲养在帆布中”“生存恶劣”?回应
- 每日速递:横滨水手门将后卫携手”犯病“ 送胜利船前锋空门得分
- 惊了!这只股票崩了,前1天一度飙涨超1100%|全球独家