使用 Spring Cloud Bus 和 Spring Cloud Stream 集成实现基于消息的事件驱动 - 行业资讯 -

当前位置:首页  >  行业资讯  > 正文

使用 Spring Cloud Bus 和 Spring Cloud Stream 集成实现基于消息的事件驱动

使用 Spring Cloud Bus 和 Spring Cloud Stream 集成实现基于消息的事件驱动
2023-04-23 09:51:43 来源:腾讯云

基于消息的事件驱动是一种常见的微服务架构设计模式,它将不同的微服务之间通过消息进行通信,实现松耦合、高可伸缩性和高可靠性。在这种架构下,每个微服务都是独立的,它们可以在消息传递的过程中进行异步操作,这使得整个系统的性能得到了很大的提升。

在 Spring Cloud 中,我们可以使用 Spring Cloud Bus 和 Spring Cloud Stream 集成来实现基于消息的事件驱动。Spring Cloud Bus 是一个消息总线,它可以在微服务之间传递消息,可以将所有微服务视为一个整体,向所有微服务广播消息或向指定的微服务发送消息。Spring Cloud Stream 是一个消息驱动的微服务框架,它可以轻松地将消息通道与微服务进行集成。

准备工作

首先,我们需要在 pom.xml 文件中添加以下依赖:


(资料图)

    org.springframework.cloud    spring-cloud-starter-bus-amqp    org.springframework.cloud    spring-cloud-stream-binder-rabbit

这些依赖将会引入 Spring Cloud Bus 和 Spring Cloud Stream 的相关库,并且使用 RabbitMQ 作为消息代理。如果你想使用其他消息代理,可以根据实际需求进行修改。

创建消息通道

在这个例子中,我们将创建一个名为 myChannel 的消息通道,用于在微服务之间传递消息。在创建消息通道之前,我们需要在 application.yml 文件中添加以下配置:

spring:  cloud:    stream:      bindings:        myChannel:          destination: myChannel

这个配置将创建一个名为 myChannel 的消息通道,并将它绑定到 RabbitMQ 的 myChannel 队列上。现在,我们可以在代码中使用 @Input 和 @Output 注解来定义输入和输出消息通道了。

public interface MyChannel {    String INPUT = "myInput";    String OUTPUT = "myOutput";    @Input(INPUT)    SubscribableChannel input();    @Output(OUTPUT)    MessageChannel output();}

这个接口定义了一个名为 MyChannel 的消息通道,其中包括一个名为 myInput 的输入消息通道和一个名为 myOutput 的输出消息通道。

发布消息

在这个例子中,我们将创建一个名为 MyController 的控制器类,该类将发布一个名为 MyMessage 的消息到 myOutput 消息通道上。

@RestControllerpublic class MyController {    @Autowired    private MessageChannel output;    @PostMapping("/send")    public void sendMessage(@RequestBody MyMessage message) {        output.send(MessageBuilder.withPayload(message).build());    }}

这个控制器类注入了名为 output 的 MessageChannel,用于向 myOutput 消息通道发送消息。在 sendMessage 方法中,我们通过 MessageBuilder 创建一个名为 message 的 MyMessage 消息,然后通过 output.send 方法将这个消息发送到 myOutput 消息通道上。

处理消息

在这个例子中,我们将创建一个名为 MyListener 的监听器类,该类将监听 myInput 消息通道上的消息,并将消息打印到控制台上。

@EnableBinding(MyChannel.class)public class MyListener {    @StreamListener(MyChannel.INPUT)    public void handleMessage(MyMessage message) {        System.out.println("Received message: " + message);    }}

这个监听器类使用 @EnableBinding 注解将 MyChannel 消息通道绑定到 Spring Cloud Stream 上。在 handleMessage 方法中,我们使用 @StreamListener 注解监听 myInput 消息通道上的消息,当有消息到来时,Spring Cloud Stream 将自动将消息转换为 MyMessage 类型,并将其传递给 handleMessage 方法进行处理。在这个例子中,我们只是简单地将消息打印到控制台上,你可以根据实际需求进行修改。

运行测试

现在,我们已经创建了消息通道、发布了消息和处理了消息,我们可以启动应用程序并测试它了。首先,我们需要在终端窗口中启动 RabbitMQ,执行以下命令:

cssCopy codedocker run -d --name rabbitmq -p 5672:5672 -p 15672:15672 rabbitmq:3-management

这个命令将启动一个名为 rabbitmq 的容器,并将其映射到本地主机的 5672 和 15672 端口上。现在,我们可以启动应用程序并访问 http://localhost:8080/send发送消息了。在控制台中,你应该可以看到类似下面的输出:

Received message: MyMessage{id=1, content="Hello, world!"}

这表明消息已经成功传递到了 myInput 消息通道,并被 MyListener 监听到并处理了。

标签:

(责任编辑:news01)
天天新动态:杭州专门开了一场关于“花”的会,杭州网红花该走向何方?

天天新动态:杭州专门开了一场关于“花”的会,杭州网红花该走向何方?

花,对于杭州城市,对于杭州市民,意义总不一样。杭州人爱四五月份堵车不堵心的满城高架月季,被城市阳...
04-22 04:26:47
天天最资讯丨12部大片感受北京光影魅力!4月22日1905APP佳作连播

天天最资讯丨12部大片感受北京光影魅力!4月22日1905APP佳作连播

↓↓↓↓↓【正在直播点此查看】“我都快三十的人了,一起感受电影的魅力吧!↓↓↓↓↓【正在直播点此...
04-22 03:58:55
超声电子(000823):4月21日北向资金减持97.15万股_速讯

超声电子(000823):4月21日北向资金减持97.15万股_速讯

4月21日北向资金减持97 15万股超声电子。近5个交易日中,获北向资金减持的有3天,累计净减持109 28万...
04-22 03:50:50
孟晚舟要去美国出差? 华为:纯属造谣

孟晚舟要去美国出差? 华为:纯属造谣

凤凰网科技讯4月21日消息,近期网上流传“孟晚舟要去美国出差”,华为表示,纯属造谣,孟晚舟女士未说过...
04-22 03:17:16
每日热议!潮州市潮安区伟华五金电器有限公司_关于潮州市潮安区伟华五金电器有限公司介绍

每日热议!潮州市潮安区伟华五金电器有限公司_关于潮州市潮安区伟华五金电器有限公司介绍

1、潮州市潮安区伟华五金电器有限公司于2005年06月15日成立。2、法定代表人黄伟奇,公司经营范围包括:...
04-22 03:10:56
每日视点!日本学者:中国农村创新发展经验值得借鉴

每日视点!日本学者:中国农村创新发展经验值得借鉴

土居健市在青年汉学家活动沙龙上发言。中外语言交流合作中心供图人民网北京4月21日电(记者陈思)“和十...
04-22 03:10:13
五一国内游预订全线超越2019年 机票酒店价格涨幅明显

五一国内游预订全线超越2019年 机票酒店价格涨幅明显

距离“五一”假期只剩不到10天,携程、飞猪等平台发布的报告都显示,平台上的国内机票、酒店、景区门票...
04-22 02:47:11
平均值定理考研可以直接用吗_平均值定理-环球即时

平均值定理考研可以直接用吗_平均值定理-环球即时

1、均值定理,别称:基本不等式,均值不等式。2、均值定理:如果a>0,b>0,那么a+b≥2√ab(当且仅当a=b取
04-22 02:45:16
余飞巡回检察组关系图_余飞 纪检监察员

余飞巡回检察组关系图_余飞 纪检监察员

1、余飞,男,汉族,1991年2月出生,江西广丰人,2013年12月参加工作,大学学历,2009年至2013年7月进修于
04-22 02:03:11
环球即时:招商蛇口:一季度实现收入150.08亿元

环球即时:招商蛇口:一季度实现收入150.08亿元

4月21日,招商蛇口发布2023年一季度报告。报告期内,公司营业总收入1,500,880 85万元,同比减少20 17%...
04-22 01:50:19
犀牛看市0421:上证指数跌近2%险破3300点 新冠药板块异动 环球新消息

犀牛看市0421:上证指数跌近2%险破3300点 新冠药板块异动 环球新消息

作者:范青华4月21日,A股三大指数开盘涨跌互现,全天市场震荡下挫,上证指数跌近2%创年内最大单日跌幅...
04-22 01:08:53
库里36分勇士114:97战胜国王,1:2后勇士将比分追平已成大概率|每日报道

库里36分勇士114:97战胜国王,1:2后勇士将比分追平已成大概率|每日报道

前两场比赛,勇士三分球出手分别达到了50次和40次,今天他们的疯狂三分出手,已经成为必然。今天的上半...
04-22 00:47:45
世界视点!今日2013抢先版Word的顺序在哪里?

世界视点!今日2013抢先版Word的顺序在哪里?

2013抢先版Word的顺序在哪里?很多人还不知道,现在让我们一起来看看吧!1、在“开始”选项卡的最右侧,...
04-22 00:38:24
天天观热点:丽水学院录取分数线2022(丽水学院录取分数线)

天天观热点:丽水学院录取分数线2022(丽水学院录取分数线)

1、这个分数要招生结束后才会出来阿 =。2、=你可以看一下近几年的分数估计一下凭我的经验报外省预...
04-22 00:00:05
阅读教学如何有效实施朗读指导_阅读教学如何有效实施

阅读教学如何有效实施朗读指导_阅读教学如何有效实施

1、呵呵,我来答答看!!《小学语文新课程教学法》笔记大纲一、课程性质与任务本课程从语文课程的标准、目...
04-21 23:30:12
瑞达期货: 2022年年度股东大会决议公告|世界焦点

瑞达期货: 2022年年度股东大会决议公告|世界焦点

瑞达期货:2022年年度股东大会决议公告
04-21 22:56:37
日本多地发生禽流感 鸡蛋供应短缺价格高涨_播资讯

日本多地发生禽流感 鸡蛋供应短缺价格高涨_播资讯

从2022年年底开始,日本各地连续发生多起严重的禽流感疫情。
04-21 22:44:20
博时招商蛇口产业园REIT一季度收入约2980.89万元

博时招商蛇口产业园REIT一季度收入约2980.89万元

截止2023年3月31日,本期收入约人民币2980 89万元,本期净利润1109 45万元,本期经营活动产生的现金流...
04-21 21:59:08
全球百事通!java入门教程115_java入门教程

全球百事通!java入门教程115_java入门教程

你们好,最近小活发现有诸多的小伙伴们对于java入门教程115,java入门教程这个问题都颇为感兴趣的,今天...
04-21 21:46:26
pedulilindungi app_印度尼西亚防疫软件_ped 世界简讯

pedulilindungi app_印度尼西亚防疫软件_ped 世界简讯

1、ped是机械工程师职位。以上就是【pedulilindungiapp(印度尼西亚防疫软件),ped】相关内容。
04-21 21:40:08
全球新动态:骄成超声:公司是国家级专精特新“小巨人”企业

全球新动态:骄成超声:公司是国家级专精特新“小巨人”企业

每经AI快讯,有投资者在投资者互动平台提问:公司是否满负荷生产,是专特精新小巨人吗?骄成超声(68839...
04-21 21:13:52
每日看点!6周至5岁可用 辉瑞13价肺炎疫苗扩龄啦

每日看点!6周至5岁可用 辉瑞13价肺炎疫苗扩龄啦

新京报讯(记者张秀兰)4月20日晚间,辉瑞公司宣布,旗下13价肺炎球菌多糖结合疫苗(PCV13)(以下简称1...
04-21 20:31:17
主动向组织交代问题!江西省科学院党组副书记、院长杨文斌被查,历任南昌市副市长、九江市市长

主动向组织交代问题!江西省科学院党组副书记、院长杨文斌被查,历任南昌市副市长、九江市市长

4月21日,中央纪委国家监委网站讯江西省科学院党组副书记、院长杨文斌涉嫌严重违纪违法,主动向组织交代...
04-21 20:15:22
当前视讯!绿色风电促发展

当前视讯!绿色风电促发展

4月20日,蓝山县百叠岭风电场,风电机组耸立在青山之巅,与蓝天白云相映成景。近年来,该县利用高山风力...
04-21 20:03:54
第四届中国未来景区大会:数字化提高旅行场景 ,状况详细介绍

第四届中国未来景区大会:数字化提高旅行场景 ,状况详细介绍

中国网4月21日讯4月19日至4月21日,第四届中国未来景区大会(常熟小城故事)在江苏省常熟市举行,大会主...
04-21 20:02:53
观速讯丨男子深夜跃入长江轻生 危急时刻两名民辅警跳江救人

观速讯丨男子深夜跃入长江轻生 危急时刻两名民辅警跳江救人

封面新闻记者伍勇4月20日,封面新闻记者从四川宜宾三江公安分局获悉,4月18日晚,三江新区一男子情绪激...
04-21 19:22:31
焦点精选!转移印花工艺流程_转移印花

焦点精选!转移印花工艺流程_转移印花

1、使用较多的转移印花方法是利用分散染料在合成纤维织物上用干法转移。2、这种方法是先选择合用的分散...
04-21 19:11:02
牵引卡车模拟2010下载_牵引卡车模拟2010-世界观速讯

牵引卡车模拟2010下载_牵引卡车模拟2010-世界观速讯

1、阻截左面T右面U码头拖车Z码头绳O扩大坡道L压缩绳I压缩坡道L左转←右转→加速↑减速↓双闪s转向左N ...
04-21 18:15:22
深州市气象台更新大风蓝色预警【Ⅳ级/一般】 天天快消息

深州市气象台更新大风蓝色预警【Ⅳ级/一般】 天天快消息

深州市气象台更新大风蓝色预警【Ⅳ级 一般】
04-21 18:10:52
全球热推荐:上海六福黄金现在多少钱一克(2023年4月21日)

全球热推荐:上海六福黄金现在多少钱一克(2023年4月21日)

金投黄金网4月21日讯,上海黄金价格_上海六福黄金现在多少钱一克
04-21 17:51:16

为您推荐

精彩推送