基于消息的事件驱动是一种常见的微服务架构设计模式,它将不同的微服务之间通过消息进行通信,实现松耦合、高可伸缩性和高可靠性。在这种架构下,每个微服务都是独立的,它们可以在消息传递的过程中进行异步操作,这使得整个系统的性能得到了很大的提升。
【资料图】
在 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 监听到并处理了。
标签:
最新推荐
基于消息的事件驱动是一种常见的微服务架构设计模式,它将不同的微服务之间通过消息进行通信,实现松耦...
国家非遗遇上沉浸式演艺秀!第九届中国(临朐)沂山文化节亮点纷呈
4月20日,雷电微力(301050)融资买入1696 89万元,融资偿还981 08万元,融资净买入715 81万元,融资余额3 64亿元。
南通网讯(记者唐佳美通讯员袁华杨谷生)17日,启东市农业农村局联合海事、海警、吕四港镇渔业渔港局开...
不能因为自己到达现代化的彼岸,就过河拆桥,给别国实现现代化设置路障,更不能因为别国走不同的现代化...
今日谷雨,宜宾“俯冲式”降温来了!
海航控股4月20日公告,2022年营业收入2264亿元,同比下降376%;净亏损2047亿元,上年同期归母净利润421...
为进一步促进中国门窗幕墙行业健康发展,积极推动门窗幕墙产业转型升级,促进国家“扩内需、促消费”战...
海外网4月21日电据美国广播公司4月20日报道,美国科罗拉多州一名校车司机为提醒车上的儿童注意乘车安全...
日前,正值香柚花开的季节,江永县10多万亩柚花相继绽放。在粗石江、桃川等香柚主产区,每天都有成百上...
1、四川农业大学是一本。2、四川农业大学,也是不错。3、四川农业大学,是由四川省人民政府主管的省属重...
《科创板日报》4月21日讯(编辑邱思雨)近日,英伟达与慕尼黑大学等院校的研究人员联合发布了一篇有关视...
今天小编肥嘟来为大家解答以上的问题。穿越清宫剧小说,穿越清宫之天为谁春相信很多小伙伴还不知道,现在...
原标题:椰视频|就业在海南逐梦自贸港!海南高校毕业生留琼就业率超六成点击查看更多视频新海南客户端、...
根据德国联邦政府方面当地时间18日发布的声明,德国在过去一周内向乌克兰交付了一套“爱国者”防空系统...
欧冠1 4决赛次回合,那不勒斯在马拉多纳球场以1-1的比分战平米兰。但是,由于首回合以0-1的比分落败,...
据中国生物官微消息,4月17日,国药集团中国生物兰州生物制品研究所自主研发的口服三价重配轮状病毒减毒...
挖贝网4月20日,惠丰钻石(839725)发布2023年第一季度报告,公告显示,2023年第一季度营业收入为108,76
1、疾病分析:水对人体的重要性应该体现在以下几点:1。2、水是人类生存的必要条件,人类的生存离不开水...
为了欧冠冠军,大巴黎已经投入了超过14亿欧元,但他们最好的成绩也只是闯进决赛。毫无疑问,梦想还得继...
可以骑的行李箱、机械臂咖啡机……广交会创新产品引关注参展企业订单增加,广交会,咖啡机,行李箱,机械,客商
《中国农业展望报告(2023—2032)》4月20日上午发布。2023年的《展望报告》总结回顾了18种主要农产品2022
丹科B股2022年报显示,公司主营收入9 34亿元,同比下降14 13%;归母净利润-2 93亿元,同比下降181 5...
1、宁字的繁体与简体写法对照图片如下:拼音:níngnìngzhù部首:宀笔画:5宁字的注释:[
国产剧最近真出息了,这一部也很香,婚姻,蒋杰,姐弟恋,国产剧,爱情剧,老戏骨
20日,有网友爆料称,在2023第二十届上海国际汽车工业展览会(下称上海车展)的宝马MINI展台上,工作人员...
格隆汇4月19日丨有投资者向理工导航(688282 SH)提问:公司后续的研发计划?理工导航回复:公司专注于惯...
【洽洽食品:子公司拟规划新建生产线】洽洽食品公告,规划新建年产39000吨瓜子生产线和年产6000吨坚果生...
今天来聊聊关于x龙时代辛云最后和谁在一起,x龙时代辛云和燕轻盈滚床单的文章,现在就为大家来简单介绍...
中新网4月20日电美国《国会山报》19日发布纽约市立大学公共卫生与卫生政策学院学者林登·哈维兰(LyndonH...
大奖得主现身兑奖理性购彩、量力而行是我们一直推崇的购彩理念,花上不多的零钱,坚持自己的爱好,一旦...
观点网讯:4月17日,据坪山人才安居公司消息,2023年,深圳坪山区加快保障性住房建设,年内将有安居御龙...
1、爱心彩虹可以用来换收集勋章、25个爱心彩虹得爱心彩虹勋章,150个爱心彩虹得爱心彩虹先锋勋章,500个...
今天闲来无事,去了离家比较近的小米之家体验了一下昨晚发布的小米13Ultra,因为这款手机现在太火爆了,...
“多亏了王彪的帮忙,我这60多的老头子,也给电动车进行了登记上牌,非常快,再也不怕电动车丢了”。4月...
1、王者荣耀中英雄适合带坦克。因为坦克型的英雄,主要是在团战前排吸收伤害,承受伤害时间越久,对战局...
《长月烬明》热播了吗?从数据上来看,上线两日,《长月烬明》就成为优酷热度最快破万剧集,不止在站内...
据了解,目前特斯拉仅有位于美国加利福尼亚州莱思罗普市的一家储能超级工厂,但订单已排到明年四季度,...
19日下午,第133届广交会第一期展览的最后一天,境内外参展商开始陆续撤场,来自全球的客商推着行李箱,...
4月21日,A股上市公司德石股份发布2022年全年业绩报告。其中,净利润7649 73万元,同比增长22 58%。根...
武汉汉南区上小学需要什么手续?(公办+民办)1 公办义务教育学校新生入学有三个程序:一是按规定登记...
金融界4月20日消息,宝马mini冲上热搜,一个视频爆火。
新政将从明年7月起生效。澳大利亚财政部当地时间周四公布了一份针对澳大利亚联储的独立评估审查报告,提...
日丰集团融入粤港澳大湾区,擘画管道民族品牌新图景
2023年新消费赛道,可以说是正在回暖中。根据驼鹿新消费不完全统计,2023年3月份,新消费赛道共计发生69...
特别是若风那可是来一波爆料,在没打英雄联盟之前,大多数人都知道若风是打刀塔的,而当时正好和马甲哥...
4月19日,国家企业信用信息公示系统显示,近日,上海永瑞合私募基金管理有限公司成立,注册资本1000万人...
今天来聊聊关于腐蚀游戏攻略,腐蚀游戏的文章,现在就为大家来简单介绍下腐蚀游戏攻略,腐蚀游戏,希望...
北京社保月缴费基数5869是多少?退休工资如何计算的?社保网小编整理来看看。北京社保缴费基数5869,退...
行为决定习惯,习惯决定品质,品质决定命运。为进一步加强学生校园行为习惯,培养学生良好的道德品质和...
知识分享 为什么无线路由器连不上
韶关始兴:推进21万亩高标准农田建设,全力筑牢“粤北粮仓”_视点
全球观速讯丨澳门冠军赛:男单16强出炉!国乒4胜1负,樊振东连扳3局大逆转
弥补“效率赤字”,破解“供需矛盾”,中巴携手推进全球治理体系改革
百合股份(603102)4月20日主力资金净卖出463.00万元_环球热议
当前快看:均瑶健康2022年营收9.86亿 净利7663.13万 董事长王均豪薪酬289.33万
恒光股份:4月19日融资买入136.75万元,融资融券余额2.03亿元|世界独家
【环球热闻】深陷争议漩涡的长峰医院:负债数亿,旗下医院曾涉医托骗局
冯潇霆再谈“冯巩之争”:为国足踢球压力太大 希望舆论环境能好一些 世界观察
公开宣布:淄博专业牛皮癣医院(评价榜)淄博治疗牛皮癣的的费用花多少钱
大华股份(002236)盘中异动 股价振幅达7.7% 上涨6.9%(04-19)
Copyright © 2015-2022 世界律师网版权所有 备案号:琼ICP备2022009675号-1 联系邮箱:435 227 67@qq.com