2023-04-20 15:02:58 来源:腾讯云
基于消息的事件驱动是一种常见的微服务架构设计模式,它将不同的微服务之间通过消息进行通信,实现松耦合、高可伸缩性和高可靠性。在这种架构下,每个微服务都是独立的,它们可以在消息传递的过程中进行异步操作,这使得整个系统的性能得到了很大的提升。
(资料图)
在 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 监听到并处理了。
标签:
- 加快虚拟仿真实训基地建设 启动职业学校信息化建设试点很必要
- “双减”后如何在满足学生多样需求方面做“加法”?
- 处于生理活跃期且心理发展不成熟 高校开设公共卫生必修课很必要
- 打造高水平人才队伍 爱与希望的种子正在西部地区发芽
- 河南封丘“学生餐后呕吐腹泻”调查:配餐点“未批先餐” 家长盼说法
知识
- 他把银行卡卖给骗子,“黑吃黑”“截胡”十万元
- “老司机”4S店试驾豪车 结果油门当刹车撞了
- 新开工改造城镇老旧小区5.34万个
- 发动巡河志愿者2万余名 “用心护好每一条河”
- 假客服的套路:伪装成大平台客服,层层布局引人上钩
人物
- 使用 Spring Cloud Bus 和 Spring Cloud Stream 集成实现基于消息的事件驱动
- 安徽省造老银元价格(2023年04月20日)
- 天天热点评!男人真正珍惜一个女人,往往会有三个表现,很明显
- 高通量基因分析仪_关于高通量基因分析仪简述_环球百事通
- 千味央厨:001215千味央厨投资者活动记录表 环球快报
- 爱媛果冻橙和沃柑的区别?_当前热点
- 快资讯丨深化智慧执行“854模式”改革 南通在全省法院现场会上交流经验
- 2023广州花都区幼儿园报名时间一览|世界今头条
- 全球十大最富裕城市中国占三席:香港、北京及上海
- 世界新资讯:创意手工“连连看”
- 菜头的家常做法_菜头
- 夏季空调开启前这些准备工作必须做到位!很多人都忽视了
- 斩获金奖!航天科工二院先进雷达服务数字中国建设
- 海亮股份:4月19日融券卖出3.13万股,融资融券余额13.07亿元
- 北大医药:2022年公司并未发生定增事项
- 高透滤棒成形纸_关于高透滤棒成形纸简述_焦点消息
- 四川比选日报网地址查询_四川比选日报网地址_看热讯
- 木兰的人物形象从那句看出来的 木兰的人物形象
- 全球连线|美国抗疫乱象之一:百万之殇 无尽之痛-当前最新
- 1亿“特种兵”已经到过西安,还有5亿在路上
- 世界动态:太阳首发今日合砍110分,队史季后赛近17年来最高
- 自贡泸州和重庆争火锅起源地 四川曾提出重庆火锅应统称四川火锅
- 首届中国人像摄影行业发展大会在南宁召开
- 辽宁发行250亿元中小银行专项债 拟注资辽宁省省级农商行
- 信息:直奔到乐球什么时候开播_直奔
- 淘宝直播流量券怎么用?如何获得淘宝直播流量券?_新要闻
- 次回合即将开踢!曼城官推晒战拜仁海报:斯通斯和哈兰德出镜|天天热点
- 实时焦点:“五一”假期机票预订增速明显,航司新增航线满足出行需求
- 太阳战胜快船扳回一局仍凸显两大短板:替补太像替补内线太谦虚-环球快看
- “水之回响——2023中国银川黄河文化旅游节特展”亮相银川
- 盈利过后难言“上岸” 叮咚买菜加码预制菜寻后续增长 环球聚焦
- 误发“福建古田4.2级地震预警”,成都高新减灾研究所致歉
- 环球速看:《去往赫布里底群岛的最后一只狐狸》入围莫斯科国际电影节!
- 施耐德开关插座怎么样_施耐德开关怎么样|世界快资讯
- 立免网怎么注册 立免网 全球聚看点
- 西藏公共文化服务:文艺馨香 惠民润心
- 国家发改委:坚决遏制铁矿石价格的不合理上涨 促进铁矿石市场平稳运行
- 乌鲁木齐市达坂城区 志愿者在行动 乡村面貌展新颜|焦点速讯
- 中小银行存款利率集体“补降” 未来或进一步下行-天天日报
- 焦点观察:驳斥七国集团外长会联合声明涉华内容
- 智商最高多少_智商多少算高
- 加快推进天开高教科创园建设 各项政策支持 铺就科创大道
- 头发少的短发发型女(头发少的短发发型)_天天热头条
- 每日速讯:天开园探索“学科+人才+产业”创新发展模式 把“聚宝盆”转化成“动力源”
- 女性人体结构图_人体自燃之谜
- 全球通讯!国内油价迎年内最大涨幅 业界:国际油价短期将震荡偏强运行
- 焦点热讯:徐汇开启2023年全球推介会 首站亮相狮城新加坡
- 独山子石化智能化系统保障装置平稳运行-天天热消息
- 明溪县气象台发布雷电黄色预警【Ⅲ级/较重】【2023-04-19】
- 天天讯息:买它还是Model Y?小鹏G6亮相:首发前后一体压铸 最新XNGP系统加持
精彩阅读
- 复星瘦身,郭广昌不再是中国巴菲特?
- 3条旅游精品线路邀您去体检 临安区举行第十一届茶俗文化旅游节 天天短讯
- 当前要闻:明阳智能:4月18日融资买入5756.79万元,融资融券余额20.76亿元
- 淄博要将方舱改旅舍接待游客?当地文旅部门:暂未收到通知
- 看电视软件推荐不用vip_看电视软件
- 犀牛宝借款逾期30天还不起征信会怎么样 环球关注
- 焦点观察:落絮飘香(关于落絮飘香的简介)
- 海信售后服务价目表_海信售后 全球球精选
- 环球头条:小米今晚的发布会,怎么像是在发布相机。。。
- 涉嫌严重违纪违法!云南镇雄县政协党组副书记鲁绍延接受审查调查-热讯
- 智秀我爱你的韩文_我爱你的韩文
- 中日韩自贸区板块4月18日涨0.1%,新华锦领涨,主力资金净流出1.15亿元|重点聚焦
- 卡斯卡里诺:夺冠与否这对阿森纳都是成功赛季,足球不是非黑即白|速讯
- 每体:梅西仍与几位巴萨前队友保持联系,私下对回归持开放态度
- 鑫苑服务(01895.HK)已就抵押事项提交仲裁_世界即时看
- 委比选股公式怎么样写_委比选股公式
- 每日简讯:《被触手怪养大的少女》第七十三章 震军刻海
- 暴君龙怎么召唤_暴君龙
- 台州机场在哪儿_台州机场在哪里 焦点快播
- 影响问题解决的主要因素有哪些口诀_影响问题解决的主要因素有哪些_世界看热讯
- 观热点:徕卡光学全新突破!小米13 Ultra开启“移动影像光学时代”
- 埃里克森目前无法在意甲出场除非他移除心脏除颤器
- 上海莱士:感谢您对我公司的关心和支持!本次换届选举正在推进中,尚需履行相关审议程序|世界观天下
- 当前头条:关于樱花的唯美句子长_关于樱花的唯美句子
- 欧盟议会:支持欧盟到2030年将碳市场排放量从2005年的水平减少62% 环球最新
- 新消息丨北京城乡: 北京城乡关于开设募集资金专项账户并授权签署募集资金三方监管协议的公告
- 观速讯丨CXO 龙头药明康德又遭减持,2 年市值增发超 2500 亿,难摆脱“绩热股冷”困境
- 易具精工2022年净利138.31万 同比下滑22.36%-当前热文
- 【新华500】新华500指数(989001)18日上涨0.24%|视焦点讯
- 蓝特光学:长条棱镜产品销量下降,2022年年归母净利润同比下降31.38%
- 2023深圳夏天是闷热吗
- 陕西商州法院特别定制普法“订单”守好校园法治教育主阵地
- 假期临近 4A景区却被拍卖了… 快资讯
- 【环球快播报】镶可以组什么词,镶可以组什么词语
- 家庭餐饮消费需求爆发 金锣“一站式家庭肉制品解决方案”将亮相2023中国国际肉展 当前快讯
- 广州为明国际学校是一所什么学校?-新视野
- 4月18日国内硫酸价格下跌5.03% 天天即时
- 核污水排海导致福岛产品“风评被害”?日本政府:不得压价或拒绝销售 环球热推荐
- 金融机构专家:中国经济一季度增长呈现出诸多亮点 前景“稳中向好” 观焦点
- 4月18日新股速递_视点
- 中科曙光:已为“紫东太初”等多个国内大模型训练提供算力支持
- 2-0战胜勇士的,是另一个版本的水花兄弟
- 播报:5米多长纯电轿车 岚图追光上市:配半固态电池
- 金门突停电“小三通”一度停摆 九千住户受影响-环球通讯
- 微动态丨国网福建电动打造全省首座全液冷超充站,助力绿色美好出行
- 石阡中医院:中医康复让患者重燃生活新希望
- 中科曙光4月18日打开涨停_全球热资讯
- 老子有关诚信的名言_有关诚信的名言和故事 每日快讯
- 讯息:2022~2023年安徽企业退休人员养老金上调新消息 安徽2023年养老金调整细则
- 璟点超级大奖赛石家庄站第一阶段签表 4月18日12:00如约开战!