使用 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-22
- Socket编程基础-Socket编程基础 世界球精选2023-04-22
- UE4 内存写坏导致异常崩溃问题记录_天天日报2023-04-22
- 湖北省黄石市2023-04-22 04:49发布雷电黄2023-04-22
- 熊出没之夺宝熊兵下载 mp4 熊出没之夺宝2023-04-22
- 天天热点评!元始天尊是道教三清的哪一位 2023-04-22
- 元祖雪月饼哪款最好吃又健康 元祖雪月饼哪2023-04-22
- 美国三大股指初步微幅收涨约0.1%2023-04-22
- 大立科技(002214.SZ):一季度业绩预亏39002023-04-22
- 甘肃金昌发挥“三酸两碱”资源优势 打造化2023-04-22
- 全球动态:西部陆海新通道金融服务联合体在2023-04-22
- 「绿色中国」无限好“风光”:江苏太仓零碳2023-04-22
- 2023上海车展:捷尼赛思G90国内首发并开启2023-04-22
- 【全球聚看点】华夏基金华夏全球精选_华夏2023-04-22
- 价格歧视名词解释答案_价格歧视名词解释 2023-04-22
- 环球看点!红烧带鱼怎么做好吃又简单窍门_2023-04-22
- 环球今头条!山东省公安厅举办习近平新时代2023-04-22
- 泓博医药:2022年净利同比降8.7% 拟10转42023-04-22
- 观天下!首创证券2023年一季报:归母净利润2023-04-22
- 保险理赔收入会计分录_保险赔偿收入会计分2023-04-22
- 环球信息:以练代战!夯实消防安全“硬实力2023-04-22
- 馆校携手奉上“阅读大礼”,让书香溢满校园2023-04-22
- 强能力重实效 雨花区组织开展应急管理系统2023-04-22
- 婚车开AP连环追尾?小鹏辟谣:去年的事,有2023-04-22
- 土耳其实现黑海天然气供应 将满足本国约302023-04-22
- 巢湖市旗山水郡安置点工程获“安徽省建筑安2023-04-22
- 世界通讯!多措并举 让勤俭节约落实见效2023-04-22
- 恒星科技2022年净利1.87亿同比增长33.5% 2023-04-22
- 六博棋哑舍_六博棋-世界快资讯2023-04-22
- 全球观点:杭银理财收成立以来首张罚单,因2023-04-22