天天速递!使用 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

标签:

最近更新

天天视讯!央行调查:未来三个月16.2%居民打算购房,比例大幅回落
2023-07-03 16:17:50
滚动:宝沃注销生产资质引热议 小米汽车面临双重考验?
2023-07-03 16:00:06
中华经典诵读大会海选作品《纸船》 环球短讯
2023-07-03 15:33:24
魔兽世界进阶畜牧业_进阶畜牧业 环球头条
2023-07-03 15:15:26
东北铁路列车运行框架全面优化 实现“进京”高铁“公交化”
2023-07-03 14:40:56
耐克2023财年营收为512亿美元,大中华区连续三季度正增长 通讯
2023-07-03 13:57:58
消息指众安智慧生活国际配售部分已获足额认购
2023-07-03 13:32:21
上市!连连数字向港交所递交招股书 今日讯
2023-07-03 12:54:52
华晨中国0.44%股权拍卖以底价1.58亿元成交 焦点
2023-07-03 12:10:27
2023 TCL全球生态合作伙伴大会亮点前瞻:即将官宣碳中和行动计划
2023-07-03 11:56:12
天天快看:新调整的“三有野生动物名录”公布
2023-07-03 11:25:33
实时焦点:暴雨蓝色预警:11省区市将现大到暴雨 江苏四川等局地有大暴雨
2023-07-03 10:55:07
来山西地质博物馆领略大美山西吧|世界即时看
2023-07-03 10:55:55
《火影忍者:终极风暴羁绊》发布原创剧情模式预告-焦点速读
2023-07-03 10:08:46
滑雪气垫大跳台 四川选手夺冠-环球热讯
2023-07-03 09:52:31
济南3日下午起雷雨先行,后半夜全市中雨局地大雨 当前看点
2023-07-03 09:28:16
阿斯巴甜安全性受质疑 更全面审查尚在进行中
2023-07-03 08:55:30
“木头姐”在特斯拉公布交付数据前又抛售近1900万美元股票
2023-07-03 08:34:04
可变身迷你房车 斯柯达Roadiaq官图|焦点播报
2023-07-03 07:54:59
快播:pocketBook电纸书阅读器怎么样?自已看内幕,好坏判断有诀窍
2023-07-03 06:51:18
环球聚焦:家用电脑挖矿一天收益(家用电脑挖矿)
2023-07-03 05:52:39
国内首台无人智慧加油通航服务站在上海投放使用
2023-07-03 03:59:54
环球热讯:台军叫嚣解放军敢越线就开火,话音刚落,大量解放军军机出动
2023-07-03 01:04:09
张震岳好听的十首歌_张震岳的10大经典歌曲
2023-07-02 22:49:13
事关公积金、跨省通办,湖南本周提醒来了!
2023-07-02 21:40:34
通讯!四川:预计川东多条河流将发生接近或超过警戒水位洪水
2023-07-02 20:40:08
【时快讯】给群众吃“定心丸”!政策兜底 分类分级收购受损小麦
2023-07-02 19:54:07
每日速读!祝福香港如紫荆花般绽放
2023-07-02 18:33:05
如何平息骚乱?马克龙的能力和决心受到考验
2023-07-02 17:44:06
探索瞬息万变的东南亚投资与并购版图|ORIGIN大会
2023-07-02 16:56:21