使用 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
关键词:
责任编辑:hnmd004
- 使用 Spring Cloud Bus 在微服务之间传递消息示例2023-04-23
- 人固有一死或重于泰山或轻于鸿毛小练笔(人2023-04-23
- nba马刺vs热火总决赛(nba马刺vs火箭)_世2023-04-23
- 今日笔记本电脑突然发出警报声是怎么回事(2023-04-23
- 今日梦想世界御前科举的自动答题网站是什么2023-04-23
- 欧美独立站国内精品大灰狼(喜洋洋与大灰狼2023-04-23
- 谷歌将合并“谷歌大脑”和 DeepMind 组成2023-04-23
- 每日速看!奈雪的茶越亏越多,彭心还要坚持2023-04-23
- 养殖河豚正努力“游”回餐桌 环球视讯2023-04-23
- 船记感慨世事变化无常:一周前莱昂纳德看起2023-04-23
- 每日热议!淡盐水清肠排毒方法不管用为什么_2023-04-23
- 撤下“官媒”标签,推特“影子禁令”能否解2023-04-23
- 多地开展政府购买第三方服务领域问题专项治2023-04-23
- 从无到有、从小到大、从弱到强 数字产业集2023-04-23
- 日本学校十大灵异事件是什么?日本学校十大2023-04-23
- 情侣做哪些事会分手?情侣十大分手魔咒是什2023-04-23
- 世界速读:咖啡胶囊的优点有哪些?咖啡胶囊2023-04-23
- 焦点信息:世界上仰泳最快的人是谁?世界上2023-04-23
- 螺蛳粉吃多了有害吗?螺蛳粉为什么臭? 今2023-04-23
- 最新快讯!武则天到底是谁的老婆?武则天历2023-04-23
- 今日热讯:印尼巫术是否真实?印度尼西亚的2023-04-23
- 泰坦尼克号沉没之后的故事是什么?关于泰坦2023-04-23
- 环球最资讯丨马航真的消失了吗?马航上失踪2023-04-23
- 评分最高僵尸片有哪些?评分最高僵尸片排行2023-04-23
- 1-2月我国跨境电商进出口总额增近16%,伊拉2023-04-23
- 我国生态保护红线划定完成2023-04-23
- 水稻种质资源精准鉴定取得新进展2023-04-23
- 经济日报金观平:有效投资为高质量发展添动2023-04-23
- 市场消息:迪士尼计划下周裁员数千人2023-04-23
- 天天头条:海军战力有多强?未来还将有哪些2023-04-23