JAVA 多用户商城系统b2b2c-Spring Cloud Stream 介绍
介绍Spring Cloud Stream
Spring Cloud Stream是构建消息驱动的微服务应用程序的框架。Spring Cloud Stream基于Spring Boot建立独立的生产级Spring应用程序,并使用Spring Integration提供与消息代理的连接。它提供了来自几家供应商的中间件的意见配置,介绍了持久发布订阅语义,消费者组和分区的概念。
您可以将@EnableBinding注释添加到应用程序,以便立即连接到消息代理,并且可以将@StreamListener添加到方法中,以使其接收流处理的事件。以下是接收外部消息的简单接收器应用程序。
@SpringBootApplication
@EnableBinding(Sink.class)
public class VoteRecordingSinkApplication {
public static void main(String[] args) {
SpringApplication.run(VoteRecordingSinkApplication.class, args);
}
@StreamListener(Sink.INPUT)
public void processVote(Vote vote) {
votingService.recordVote(vote);
}
}
@EnableBinding注释需要一个或多个接口作为参数(在这种情况下,该参数是单个Sink接口)。接口声明输入和/或输出通道。Spring Cloud Stream提供了接口Source,Sink和Processor; 您还可以定义自己的界面。
以下是Sink接口的定义:
public interface Sink {
String INPUT = "input";
@Input(Sink.INPUT)
SubscribableChannel input();
}
@Input注释标识输入通道,通过该输入通道接收到的消息进入应用程序; @Output注释标识输出通道,发布的消息将通过该通道离开应用程序。@Input和@Output注释可以使用频道名称作为参数; 如果未提供名称,将使用注释方法的名称。
Spring Cloud Stream将为您创建一个界面的实现。您可以在应用程序中通过自动连接来使用它,如下面的测试用例示例。
@RunWith(SpringJUnit4ClassRunner.class)
@SpringApplicationConfiguration(classes = VoteRecordingSinkApplication.class)
@WebAppConfiguration
@DirtiesContext
public class StreamApplicationTests {
@Autowired
private Sink sink;
@Test
public void contextLoads() {
assertNotNull(this.sink.input());
}
}
编程模型
Binder
Binder 是 Spring Cloud Stream 的一个抽象概念,是应用与消息中间件之间的粘合剂。
目前 Spring Cloud Stream 实现了 Kafka 和 Rabbit MQ 的binder。通过 binder ,可以很方便的连接中间件,可以动态的改变消息的destinations(对应于 Kafka 的topic,Rabbit MQ 的 exchanges),这些都可以通过外部配置项来做到。甚至可以任意的改变中间件的类型而不需要修改一行代码。
Publish-Subscribe
消息的发布(Publish)和订阅(Subscribe)是事件驱动的经典模式。Spring Cloud Stream 的数据交互也是基于这个思想。生产者把消息通过某个 topic 广播出去(Spring Cloud Stream 中的 destinations)。其他的微服务,通过订阅特定 topic 来获取广播出来的消息来触发业务的进行。
这种模式,极大的降低了生产者与消费者之间的耦合。即使有新的应用的引入,也不需要破坏当前系统的整体结构。
Consumer Groups
“Group”, Kafka 中的概念。Spring Cloud Stream 的这个分组概念的意思基本和 Kafka 一致。
微服务中动态的缩放同一个应用的数量以此来达到更高的处理能力是非常必须的。对于这种情况,同一个事件防止被重复消费,只要把这些应用放置于同一个 “group” 中,就能够保证消息只会被其中一个应用消费一次。
Message
Message,就是所说的消息体,用来承载传输的信息用的。Message分为两部分,header和payload。header是头部信息,用来存储传输的一些特性属性参数。payload是用来装载数据的,他可以携带的任何Object对象 不同的对象在binder中传输 可以指定不同的mini类型 具体参考
可以通过application.yml中设置 输入input和输出output的mini类型
spring.cloud.stream.bindings..content-type
MessageChannel
消息管道,生产者生产一个消息到channel,消费者从channel消费一个消息,所以channel可以对消息组件解耦,并且提供一个方便的拦截功能和监控功能。
默认的通道
输入(SubscribableChannel)和输出通道(MessageChannel)参考 Processor接口
springcloudstream提供通道的定义 比如自定义通过可以使用接口
public interface OrderChannel {
String INPUT = "input_order";
String OUTPUT="ouput_order";
/**
* input注解制定通道的名称 将来在yml中配置该通道的实际绑定的topic或者订阅组
* @return
*/
@Input(INPUT)
SubscribableChannel orderInput();
/**
* output注解指定输出通道的名称
* @return
*/
@Output(OUTPUT)
MessageChannel orderOutput();
}
以下 代码参考 Source Sink Processor接口 将来在yml关于该通道的配置既可以
spring:
cloud:
stream:
bindings:
通道名称:
destination: mydest

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
-
上一篇
机器视觉与图像传感器的演变
嵌入式系统中视觉技术的迅速发展,为汽车安全,机器视觉和运动分析提供了超高速成像解决方案。反过来,这说明了通过更强大的图像传感器和更小的像素架构转化为性能和成像能力的显著提升。机器视觉技术使用图像识别算法来识别图像中的对象,并且在诸如工业自动化,机器人,农业无人机和3D建模的广泛应用中实现对象的更详细和准确的图像而不失真。 首先,小巧但功能强大的处理器平台正在降低传统的机器视觉系统成本。接下来,新型图像传感器在强大,低成本和高能效处理的帮助下,正在快速发展,以满足光学检测和工业自动化等工业级成像应用的需求。图像传感器是任何机器视觉设计的关键因素,在速度和分辨率边界上都经过快速改造。新的图像传感器实现了更高的帧速率,而不会影响图像质量。而且,为了实现分辨率,这些图像传感器具有强大的光学格式,可确保现代机器视觉和检测用例所需的成像细节和性能。此外,这些低功耗嵌入式系统可以支持多种产品分辨率,同时满足各种像素功能。在这些随着新的像素架构快速发展的嵌入式视觉系统中,较大的像素可以以给定的光学格式交换分辨率以获得更高的成像灵敏度。
-
下一篇
springmvc + springboot + mybatis java b2b2c电子商城系统源码
用java实施的电子商务平台太少了,使用spring cloud技术构建的b2b2c电子商务平台更少,大型企业分布式互联网电子商务平台,推出PC+微信+APP+云服务的云商平台系统,其中包括B2B、B2C、C2C、O2O、新零售、直播电商等子平台。 技术解决方案 开发语言: java、j2ee 数据库:mysql JDK支持版本: JDK1.8 以上版本 核心技术:分布式、云服务、微服务、服务编排等。 核心架构: 使用Spring Cloud分布式微服务云架构进行服务化开发,所有模块功能完全解耦,提供服务发现、注册、配置中心、消息总线、负载均衡、断路器、数据监控等java B2B2C 多租户电子商城系统
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- SpringBoot2整合MyBatis,连接MySql数据库做增删改查操作
- SpringBoot2全家桶,快速入门学习开发网站教程
- SpringBoot2整合Redis,开启缓存,提高访问速度
- Dcoker安装(在线仓库),最新的服务器搭配容器使用
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- SpringBoot2初体验,简单认识spring boot2并且搭建基础工程
- MySQL数据库在高并发下的优化方案
- SpringBoot2配置默认Tomcat设置,开启更多高级功能