当前位置: 首页 > news >正文

中文设计网站济南竞价托管公司

中文设计网站,济南竞价托管公司,长春好的做网站公司,深圳市宝安区福永人民医院Stream 简介 Spring Cloud Stream 是用于构建消息驱动的微服务应用程序的框架,提供了多种中间件的合理配置 Spring Cloud Stream 包含以下核心概念: Destination Binders:目标绑定器,目标指的是 Kafka 或者 RabbitMQ&#xff0…

Stream 简介

Spring Cloud Stream 是用于构建消息驱动的微服务应用程序的框架,提供了多种中间件的合理配置

Spring Cloud Stream 包含以下核心概念:

  • Destination Binders:目标绑定器,目标指的是 Kafka 或者 RabbitMQ,绑定器就是封装了目标中间件的包,如果操作的是 Kafka,就使用 Kafka Binder,如果操作的是 RabbitMQ,就使用 RabbitMO Binder
  • Bindings:外部消息传递系统和应用程序之间的桥梁,提供消息的“生产者”和“消费者”(由目标绑定器创建)
  • Message:一种规范化的数据结构,生产者和消费者基于这个数据结构通过外部消息系统与目标绑定器和其他应用程序通信

应用程序通过 inputs 或者 outpus 与 Spring Cloud Stream 的 Binder 交互,Binder 层负责和中间件的通信,通过配置来 binding。通过定义 Binder 作为中间层,实现了应用程序与消息中间件细节之间的隔离,应用程序不需要再考虑各种不同的消息中间件实现。当需要升级消息中间件或是更换其他消息中间件产品时,只需要更换对应的 Binder 绑定器

在这里插入图片描述


Stream 整合 kafka

以 Kafka 为例,确保安装 Kafka 并启动

分别创建生产者和消费者项目,分别添加依赖

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-stream-kafka</artifactId>
</dependency>
1. 创建生产者

开发 MqSource 接口

public interface MqSource {@Output("test-topic")MessageChannel testTopic();@Output("test-topic-2")MessageChannel testTopic2();
}

通过 @Output@Input 注解定义消息输入和输出通道的名称定义,输出通道需要返回 MessageChannel 接口对象,它定义了向消息通道发送消息的方法。默认情况下,通道的名称就是注解的方法的名称,也能自己定义通道名称,只需要给 @Input@Output 注解传入 String 类型参数通道名称即可,这里指定两个通道分别为 test-topictest-topic-2

开发 MsgProducer 类

@Slf4j
@EnableBinding(MqSource.class)
public class MsgProducer {@Autowiredprivate MqSource mqSource;public void sendTestTopicMessage(String msg) {try {mqSource.testTopic().send(MessageBuilder.withPayload(msg).build());} catch (Exception e) {log.error("sendTestTopicMessage error", e);}}public void sendTestTopic2Message(String msg) {try {mqSource.testTopic2().send(MessageBuilder.withPayload(msg).build());} catch (Exception e) {log.error("sendTestTopic2Message error", e);}}
}

使用 @EnableBinding 创建和绑定通道,绑定通道是指将通道和 Binder 进行绑定,比如 Kafka、RabbiMQ 等。如果类路径下只有一种 Binder,那么 Spring Cloud Stream 会找到并绑定它,不需要进行配置。如果有多个就需要明确配置

调用 MqSource 接口方法获取输出通道对象,接着调用 send 方法发送数据。send 方法接收一个 Message 对象,这个对象不能直接新建,需要使用 MessageBuilder 获取

2. 创建消费者
public interface MqSink {@Input("test-topic")MessageChannel testTopic();@Input("test-topic-2")MessageChannel testTopic2();
}

与生产者的 MqSource 同理

开发 MsgReceiver 类,@StreamLisiener 接收的参数是要处理的通道名,所注解的方法就是处理从通道获取数据的方法,方法的参数就是获取到的数据

@Slf4j
@EnableBinding(MqSink.class)
public class MsgReceiver {@StreamListener("test-topic")public void testTopicMessageListen(String msg) {log.info("testTopicMessageListen: {}", msg);}@StreamListener("test-topic-2")public void testTopic2MessageListen(String msg) {log.info("testTopic2MessageListen: {}", msg);}
}

http://www.mmbaike.com/news/33663.html

相关文章:

  • php网站开发示例代码自己如何注册网站
  • 备份文件wordpress贺州seo
  • 哈尔滨网站优化如何下载百度官方网站
  • 免费制作动画网站电话百度
  • 手机网站建google网站入口
  • 国外h5制作网站模板链接生成器在线制作
  • 怎么做网站排名优化免费seo推广培训学费
  • 怎么做网站的分类目录bt磁力
  • 新媒体网站建设十大的经典成功案例网络销售怎么才能找到客户
  • 建设网站的相关技术google chrome谷歌浏览器
  • 乐清网站建设网站建设在哪里查关键词排名
  • ftp服务器搭建设置网站信息跨境电商怎么做
  • 微信分销算b2c网站吗seo门户
  • wordpress主题点赞百度词条优化工作
  • 个人可以做网站吗新闻头条最新消息今天
  • wordpress 如何修改主题中元素北京网络seo
  • 庆阳做网站长春刚刚最新消息今天
  • 校园网站建设情况说明seo网站建设优化
  • 专业网站建设微信官网开发注册公司
  • 如何让百度收录网站亚马逊seo关键词优化软件
  • 八年级微机网站怎么做实时热搜榜
  • 站长网站素材百度推广方法
  • 云服务器是否可以做多个网站明天上海封控16个区
  • 做社交网站开发网站seo推广优化教程
  • 如何做网站怎么赚钱游戏推广公司靠谱吗
  • 有没关于做动画设计师的网站seo关键词选择及优化
  • 一般网站banner做多高怎么自己开网站
  • 济南企业营销型网站建设seo平台是什么意思
  • 网站不收录原因b站推广入口在哪
  • 德州网页制作山东济南seo整站优化费用