springcloud——stream(消息驱动)基础概念原理

消息驱动的作用(SpringCloudStream):屏蔽底层消息中间件的差异,降低切换成本,统一消息的编程模型。

SpringCloudStream:是一个构建消息驱动微服务的框架。

应用程序通过inputs或者outputs来与SpringCloudStream中的binder对象交互。
通过我们配置来(binding)绑定,而SpringCloudStream的binder对象负责与消息中间件交互。
所以,我们只需要搞清楚如何与SpringCloudStream交互就可以方便使用消息驱动的方式。

通过使用Spring Integration来连接消息代理中间件以实现消息时间驱动。
SpringCloudStream为一些供应商的消息中间件产品提供了个性化的自动化配置实现,引用了发布-订阅、消费组、分区的三个核心概念。

目前仅支持RabbitMQ、Kafka。

在没有绑定器这个概念的情况下,我们的SpringBoot应用要直接与消息中间件进行消息交互的时候,由于各消息中间件构建的初衷不同,它们的实现细节上会有较大的差异性,通过定义绑定器作为中间层
,完美的实现了应用程序与消息中间件细节之间的隔离。
通过向应用程序暴露统一的Channel通道,使得应用程序不需要再考虑各种不同的消息中间件实现。

通过定义绑定器Binder作为中间层,实现了应用程序与消息中间件细节之间的隔离。

binder:input对应于消费者,output对应于生产者。

在这里插入图片描述

在这里插入图片描述

常用注解和概念

1、Middleware:中间件,目前只支持Rabbit和Kafka。
2、Binder:是应用与消息中间件之间的封装,目前实行了Kafka和RabbitMQ的Binder,通过Binder可以很方便的连接中间件,可以动态的改变消息类型(对应于Kafka的topic,RabbitMQ的Exchange),这些都可以通过配置文件来实现。
3、@Input:注解表示输入通道,通过该输入通道接收到的消息进入应用程序。
4、@Output:注解标识输出通道,发布的消息将通过该通道离开应用程序。
5、@StreamListener:监听队列,用于消费者的队列的消息接收。
6、@EnableBinding:指信道channel和exchange绑定在一起。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值