使用 Spring Cloud Bus 在微服务之间传递消息示例

2023-04-22 08:20:28 | 来源:腾讯云


(资料图片仅供参考)

下面是一个完整的示例,演示如何使用 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 在微服务之间传递消息示例

芝加哥农产品期价21日下跌

联名迈凯伦发力菁英运动,FILA深化高质量增长战略 热点在线

全球通讯!深交所向英搏尔发出关注函

环球微头条丨牧原股份:目前公司商品猪养殖完全成本低于15.5元/kg

青春期主题教育心得50字内容_青春期主题教育心得50字_世界视点

每日热闻!阿里等不了优酷了

当前热讯:重庆新村幼儿园明阳分园(重庆新村幼儿园)

英国副首相拉布宣布辞职,此前被至少24人投诉职场霸凌

CardinalOps在与全球企业客户和MSSP/MDR的市场_环球资讯

日发精机(002520):4月21日北向资金增持24.2万股-世界滚动

2023浙江温州永嘉县中医医院医共体招聘劳务派遣人员2人公告(四) 独家焦点

总受如何 耽美np总受文-快看点

登封市卢店街道:大力完善无障碍设施建设,让城市“有爱无碍”

国网蚌埠供电公司:“村网共建”共筑乡村振兴连心桥|环球快消息

最新新闻

使用 Spring Cloud Bus 在微服务之间传递消息示例

芝加哥农产品期价21日下跌

联名迈凯伦发力菁英运动,FILA深化高质量增长战略 热点在线

全球通讯!深交所向英搏尔发出关注函

环球微头条丨牧原股份:目前公司商品猪养殖完全成本低于15.5元/kg

青春期主题教育心得50字内容_青春期主题教育心得50字_世界视点

每日热闻!阿里等不了优酷了

当前热讯:重庆新村幼儿园明阳分园(重庆新村幼儿园)

英国副首相拉布宣布辞职,此前被至少24人投诉职场霸凌

CardinalOps在与全球企业客户和MSSP/MDR的市场_环球资讯

日发精机(002520):4月21日北向资金增持24.2万股-世界滚动

2023浙江温州永嘉县中医医院医共体招聘劳务派遣人员2人公告(四) 独家焦点

总受如何 耽美np总受文-快看点

登封市卢店街道:大力完善无障碍设施建设,让城市“有爱无碍”

国网蚌埠供电公司:“村网共建”共筑乡村振兴连心桥|环球快消息

我和一个少妇|速讯

每日快看:2023天津方特五一夜场营业时间+开放日期

男士香水什么牌子好闻又持久_男士香水什么牌子好闻 全球头条

情醉歌词_情醉歌简介

进修护士回来后工作计划(共12篇) 天天热点

速读:意甲最新积分榜:尤文+15分升至第三!米兰掉出前四名

环球新动态:车位税费怎么算

蘼芜的拼音_蘼

今日热文:木乃伊归来3在线观看_木乃伊归来3

承德:深入推进“我为群众办实事”实践活动

黄豆粉皮的制作方法(黄豆炒粉皮做法大全家常)

梧桐树投资平台有限责任公司待遇_梧桐树投资平台有限责任公司-每日快讯

晶科科技: 关于提前归还暂时补充流动资金的可转换公司债券募集资金的公告

2011年福建高考录取率_2011福建高考分数线-新视野

今日关注:NBA-勇士114-97国王总分追至1-2,库里36+6维金斯20+7福克斯26+10