使用 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 在微服务之...
下面是一个完整的示例,演示如何使用SpringCloudBus在微服务之间传... -
每日速看!单位与劳动者签两份合同约定两...
法院指出单位此举违法(副题)中工网讯(工人日报-中工网记者王伟通... -
现代投资:4月19日融资买入269.25万元,...
4月19日,现代投资(000900)融资买入269 25万元,融资偿还263 93... -
焦点热议:图森未来发布智能驾驶新产品
【图森未来发布智能驾驶新产品】4月19日,图森未来发布智能驾驶新产... -
雷克萨斯在上海车展首发全新一代 LM ...
4月18日,LEXUS雷克萨斯旗舰级豪华MPV全新一代LM于2023上海国际车展... -
累计凭证属于原始凭证吗_累计凭证|每日热点
1、一次凭证包括:购货发票、销货发票、领料单、借款单、银行结算凭...
精彩放送
-
使用 Spring Cloud Bus 在微服务之...
下面是一个完整的示例,演示如何使用SpringCloudBus在微服务之间传... -
每日速看!单位与劳动者签两份合同约定两...
法院指出单位此举违法(副题)中工网讯(工人日报-中工网记者王伟通... -
现代投资:4月19日融资买入269.25万元,...
4月19日,现代投资(000900)融资买入269 25万元,融资偿还263 93... -
焦点热议:图森未来发布智能驾驶新产品
【图森未来发布智能驾驶新产品】4月19日,图森未来发布智能驾驶新产... -
雷克萨斯在上海车展首发全新一代 LM ...
4月18日,LEXUS雷克萨斯旗舰级豪华MPV全新一代LM于2023上海国际车展... -
累计凭证属于原始凭证吗_累计凭证|每日热点
1、一次凭证包括:购货发票、销货发票、领料单、借款单、银行结算凭... -
天天观天下!2008年国际金融危机的实质...
今天来聊聊关于2008年国际金融危机的实质和原因,2008年国际金融危... -
特朗普欲将无家可归者逮捕“改造” 网...
海外网4月19日电据美国《新闻周刊》当地时间4月18日报道,美国前任... -
黄德几:港股恒生指数暂时受制于21000点阻力
香港市场方面,李宁今天宣布,公司已向香港联交所提交增设人民币柜... -
世界看点:新生儿上户口竟被标注为“文...
近日山东省临邑县一居民在网上反映自己给新生孩子上户口时民警在孩...