使用 Spring Cloud Bus 在微服务之间传递消息示例-焦点滚动

2023-04-20 15:42:04 | 来源:腾讯云


(资料图)

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

今日聚焦!托管给“相寓” 房子变“脏了”

当前要闻:车展E快评|比亚迪硬核实力的巅峰之作 仰望U8足够让你放弃奔驰G?

世界看热讯:隆盛科技2023年一季度董事会经营评述

校友荟(NO.6)|齐乐添:马行千里,不洗沙尘_全球新资讯

GAN卷土重来:10亿参数的GigaGAN效果堪比扩散模型|全球微速讯

天天热推荐:【期市早餐】重点品种操作指南

环球快播:广西山歌怎么唱?歌圩代表性传承人带你一起玩转山歌

厄瓜多尔外贸部长:对华贸易发展不受外部压力影响 热资讯

iphone耳机模式解除_iphone耳机没声音|天天快看

汽车上的rear是什么意思_rear的含义解释

追光 | 摸鱼,真的很快乐

“3桌家常饭的婚礼”品出婚俗改革的甜蜜味道-热门

天天速递!“农管”并非无所不管,执法还须以法为界

我要从南走到北抖音版_我要从南走到北 观热点

最新新闻

使用 Spring Cloud Bus 在微服务之间传递消息示例-焦点滚动

今日聚焦!托管给“相寓” 房子变“脏了”

当前要闻:车展E快评|比亚迪硬核实力的巅峰之作 仰望U8足够让你放弃奔驰G?

世界看热讯:隆盛科技2023年一季度董事会经营评述

校友荟(NO.6)|齐乐添:马行千里,不洗沙尘_全球新资讯

GAN卷土重来:10亿参数的GigaGAN效果堪比扩散模型|全球微速讯

天天热推荐:【期市早餐】重点品种操作指南

环球快播:广西山歌怎么唱?歌圩代表性传承人带你一起玩转山歌

厄瓜多尔外贸部长:对华贸易发展不受外部压力影响 热资讯

iphone耳机模式解除_iphone耳机没声音|天天快看

汽车上的rear是什么意思_rear的含义解释

追光 | 摸鱼,真的很快乐

“3桌家常饭的婚礼”品出婚俗改革的甜蜜味道-热门

天天速递!“农管”并非无所不管,执法还须以法为界

我要从南走到北抖音版_我要从南走到北 观热点

甲壳纲类动物有哪些_甲壳纲

智能呼吸窗_对于智能呼吸窗简单介绍|聚焦

阳光少年歌词蒋文涵 阳光少年歌词

达县是哪个市_达县

中化岩土2022年净利润亏损扩大至7.07亿元 原董事长吴延炜违规减持被罚

每日速看!湖北巴东白黄双麂罕见同框

存放二十余年的红酒能喝吗?注意哪些?谢谢?

满天星业余交响乐团亮相2023年国家图书馆“世界读书日” 全球视讯

洁美科技:4月18日接受机构调研,光大资管、广发基金等多家机构参与_全球快消息

2023上海车展:奇瑞小蚂蚁Q首发亮相

环球快看点丨4.5%!各地“拼经济”成效初显

天天快看点丨日本政府将正式成立工作组,研究生成式人工智能的利弊

70股获海外机构调研 德赛西威最受关注-全球聚看点

4月19日 13:23分 中科环保(301175)股价快速拉升 当前快看

加强基层“三保”保障 我国进一步加大中央对地方转移支付力度_全球快播