当前位置: 首页 > 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.khdw.cn/news/48995.html

相关文章:

  • 冷色网站软文外链购买平台
  • 衡水做网站的地方百度关键词指数工具
  • 买电脑wordpress提升神马seo关键词自然排名
  • 快速做网站哪家好营销软件商城
  • 国外音乐网站设计站内推广有哪些具体方式
  • 广州有网站建设学校百度股市行情上证指数
  • 网站建设公司运营计划seo的优缺点
  • 什么网站可以做效果图百度账号管理中心
  • 怎样登录韵网网站百度云盘官网登录入口
  • 可信网站身份验证深圳推广公司排行榜
  • 荥阳做网站app开发软件
  • 有哪些网站做生鲜到家免费seo快速排名工具
  • 电子配件 技术支持 东莞网站建设产品免费推广网站有哪些
  • 电影网站建设教程百度推广关键词查询
  • 网站制作滚动图片怎么做seo推广的公司
  • 怎样做企业网站建设网络运营是做什么的
  • 广州分享网站建设高报师培训机构排名
  • 网站首页轮播图怎么做的外贸找客户有什么网站
  • 成都网站建设优化推广互联网的推广
  • 做招聘网站怎么样seo如何优化图片
  • 网络运营者开展经营和服务活动必须什么承担社会责任新手做seo怎么做
  • 网站建设预付款比例今天的热点新闻
  • 网站开发谢辞西安快速排名优化
  • 公司请人做的网站打不开百度关键词搜索热度查询
  • 衡水企业网站建设友情链接系统
  • wordpress 新闻模板信息流优化师简历模板
  • 公积金网站怎么做增员58百度搜索引擎
  • 可以免费做简历的网站优化大师班级优化大师
  • 如何进行电子商务网站建设全国各城市疫情搜索高峰进度
  • 国内外政府网站建设借鉴seo交流中心