使用 Spring Cloud Bus 和 Spring Cloud Stream 集成实现基于消息的事件驱动_今日热搜
基于消息的事件驱动是一种常见的微服务架构设计模式,它将不同的微服务之间通过消息进行通信,实现松耦合、高可伸缩性和高可靠性。在这种架构下,每个微服务都是独立的,它们可以在消息传递的过程中进行异步操作,这使得整个系统的性能得到了很大的提升。
(资料图片仅供参考)
在 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 监听到并处理了。
标签:
精彩推送
世界即时看!青岛经济技术开发区属于哪个区管_青岛经济技术开发区属于哪个区
1、青岛经济技术开发区属于青岛的黄岛区。2、黄岛区包含了开发区,开发区只是黄岛区的一部分。3、黄岛区和
世界快讯:工信部听取“3·29”微信业务异常情况汇报 腾讯回应:已处罚相关负责人
工信部听取“3·29”微信业务异常情况汇报腾讯回应:已处罚相关负责人封面新闻记者欧阳宏宇4月15日,据...
突飞猛进!本赛季SGA场均31.4分&比上季高出7分 命中率大幅提升-焦点关注
NBA附加赛雷霆不敌森林狼,结束了本赛季征程。本赛季,亚历山大取得巨大进步、迈入顶级球星行列。本赛季他
新闻快讯
X 关闭
X 关闭
新闻快讯
- 使用 Spring Cloud Bus 和 Spring Cloud Stream 集成实现基于消息的事件驱动_今日热搜
- 深圳燃气:截至目前,公司尚未与深投控明确专项产业基金的设立方式和投资规模
- 百亚股份:电商渠道今年将可能实现盈亏平衡_世界播资讯
- 宝莱特2023年第一季度净利2716.22万同比增长94.75% 产品毛利率增长|全球即时
- 檀木怎么分辨真假
- 中国联通Q1营收972.22亿元,增速达近十年来同期高位水平-环球今热点
- 焦点热讯:4月20日夜间至24日西安市有一次大范围降水天气 城区最高气温可降至10~12℃
- 最新:高能问顶·续航无界 | 瑞浦兰钧“问顶”电池重磅量产首发!
- 多位基金经理加仓新能源赛道
- 8年,写下3000篇巡河日记(绿水青山守护者)
- 快消息!2005年来最低库存!铜金属拉响警报 全球目光聚焦这一国
- 罗德里戈赛后接受采访谈到自己的庆祝动作:“一开始...
- 世界热消息:质量管理体系认证_oppo手机怎么样质量好么
- 日本第一夫人用东方美貌闪耀美国!穿粉裙跟美国夫人合影,更吸睛|天天热推荐
- 微头条丨联塑下水管道材质(联塑下单系统)
- 热点聚焦:表弟的姑父怎么称呼(表弟的姑父怎么称呼他)
- 若函数y=kx-b的图像如图所示 若函数ykxb的图像如图所示则关于x_每日动态
- 4-0淘汰切尔西!罗德里戈致敬C罗,皇马英超6连斩,曼城瑟瑟发抖 焦点精选
- 商州区第三小学第五届体育艺术节暨春季运动会开幕
- 如何制作陶瓷雕塑
- 全球看点:德众汽车2022年营收同比下滑3.17% 深耕报废汽车拆解项目寻求突破点
- 环球实时:南通:知识产权强市建设取得新成果
- 龙星化工2023年第一季度净利1273.66万同比增长11.62% 所得税费用本期较上期增长-世界微动态
- 胡汉三又回来了是什么电影_胡汉三又回来了是什么意思|环球微动态
- 英国首相苏纳克因“利益申报”问题被调查 全球微资讯
- 通灵股份(301168):4月18日北向资金减持3.14万股
- 关注:2023年福州数字中国建设成果展览会中学生能参观吗
- 深圳观众热议《青春之城》创业故事:“搞事业”深圳生活的完美复刻 没有谁能随随便便成功! 当前最新
- 【好消息】60个!长春预计今年新建……_全球快播
- 一季度CPI涨幅回落 价格带动逐步增强
- 神马电力: 第四届董事会第二十次会议决议公告
- 新赛季,国羽男双表现获世界羽联肯定,实力比肩印尼男双
- 走过青春岁月作者简介_走过青春岁月_焦点简讯
- 资讯推荐:村民被当成野兔遭枪击溺亡 4人被拘具体详细内容是什么
- 档案管理方法和技巧有哪些(档案管理方法和技巧)
- 惠州楼市领涨三线城市,深圳市场回暖辐射多个临深片区
- 天天新资讯:【聚焦科交会】“揭榜挂帅”攻关核心技术
- 每日速递:多氟多2022年度10转4派6元
- 这个五一假期,还有没有真正的小众目的地了?(有,找到了) 天天热文
- 炬光科技发生4笔大宗交易 合计成交2067.55万元
- 2023年“中国航天日”宣传海报正式发布 世界热议
- 黄金在酝酿新一轮上涨还是在为瀑布做准备?
- 第二个字是然的四字成语有哪些成语_第二个字是然的成语
- 【新要闻】就算这样我还是爱着妻子3动漫_就算这样我还是爱着妻子全集
- 当前速读:白云机场:一季度归母净利润4472.62万元 同比扭亏
- 电脑怎么关不了机什么情况_电脑怎么关不了机
- 环球精选!日媒:为增强杀伤力,袭击岸田嫌犯在自制铁管炸弹上加装螺母
- 2023上海车展:比亚迪海鸥预售7.88万起 续航405km 环球精选
- 专家学者齐聚湖南师大 共话高校外语教育改革与发展
- 小米米家手持蒸汽熨烫机发布!除菌除螨、首发279元|环球微头条