介绍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 {@Autowiredprivate Sink sink;@Testpublic 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类型 具体参考

cloud.spring.io/spring-clou…

可以通过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
复制代码

java B2B2C 多租户电子商城系统

转载于:https://juejin.im/post/5cb3e148e51d456e2907f216

JAVA 多用户商城系统b2b2c-Spring Cloud Stream 介绍相关推荐

  1. JAVA 多用户商城系统b2b2c-Spring Cloud常见问题与总结(一)

    在使用Spring Cloud的过程中,难免会遇到一些问题.所以对Spring Cloud的常用问题做一些总结.需要JAVA Spring Cloud大型企业分布式微服务云构建的B2B2C电子商务平台 ...

  2. JAVA 多用户商城系统b2b2c-服务容错保护(Hystrix依赖隔离)

    依赖隔离 "舱壁模式"对于熟悉Docker的读者一定不陌生,Docker通过"舱壁模式"实现进程的隔离,使得容器与容器之间不会互相影响.而Hystrix则使用该 ...

  3. java多用户商城系统架构之第一篇——总的介绍

    系列文章主要是针对Java商城相关架构演化的介绍,不讲解具体业务.技术等. 最近公司要搞商城,让我多方咨询,最后看了很多,要不就是代码.表字段注释不全,要不就是bug多,要么就是文档缺少,最后决定自己 ...

  4. (十四)Java springcloud B2B2C o2o多用户商城 springcloud架构- Spring Cloud构建分布式电子商务平台...

    通过Spring Cloud构建PC+微信+APP+云服务的云商平台系统,其中包括B2B.B2C.C2C.O2O.新零售.直播电商等子平台,之前我们讲了很多关于Spring Cloud的概念文章,从本 ...

  5. JAVA 多用户商城系统b2b2c-kafka处理超大消息

    Kafka设计的初衷是迅速处理短小的消息,一般10K大小的消息吞吐性能最好.但有时候,我们需要处理更大的消息,比如XML文档或JSON内容,一个消息差不多有10-100M,这种情况下,Kakfa应该如 ...

  6. JAVA 多用户商城系统b2b2c---配置中心和消息总线

    Spring Cloud Bus 电子商务平台源码请加企鹅求求:一零三八七七四六二六. Spring cloud bus通过轻量消息代理连接各个分布的节点.这会用在广播状态的变化(例如配置变化)或者其 ...

  7. 分享大型Java多用户商城系统开发历程

    最近公司要搞商城,让我多方咨询,最后看了很多,要不就是代码.表字段注释不全,要不就是bug多,要么就是文档缺少,最后决定自己开发一套商城. 下面是开发的一些心得体会,权且记录下来,给自己做个记录把. ...

  8. java广告投放系统_[Spring cloud 一步步实现广告系统] 5. 投放系统配置+启动+实体类...

    广告投放系统启动主类说明 /** * sponsorapplication for 广告赞助商/投递服务启动类 * 添加注解{@link enablefeignclients}之后,当前微服务就可以调 ...

  9. 搭搭云-超级应用平台 与JNPF Java多用户商城系统源码

    搭搭云 搭搭云是非常灵活的一站式企业管理超级平台,企业在一个云端账户中即可使用包含CRM.OA.进销存.HR.财务.项目管理.ERP在内的全系列SaaS软件:应用软件开发者可以基于搭搭云低代码PaaS ...

最新文章

  1. Hawk原理:通过IEnumerable实现通用的ETL管道
  2. ubuntu16.04安装CecureCRT 并破解
  3. 【音效处理】Vibrato 简介
  4. 弹性碰撞次数与圆周率的关系 - 3Blue1Brown
  5. oeasy教您玩转vim - 88 - # 自动命令autocmd
  6. python控制风扇_Python语音控制普通风扇实现教程
  7. 双光耦开关电源电路图_光耦开关电源电路图大全(光电耦合器/可控精密稳压源)...
  8. vue3:兄弟组件,跨组件传值,事件总线的通信方式(mitt / tiny-emitter)
  9. 【题解】CF#855 G-Harry Vs Voldemort
  10. 链游的趋势和前景:团队开始专注于建设 进入 6-12 个月重新整合期
  11. 吴恩达深度学习课程-Course 4 卷积神经网络 第一周 卷积神经网络编程作业(第一部分)
  12. 深度操作系统 15.7 —— 性能好才是真的好
  13. 刘强东为苏宁易购做了嫁衣
  14. HTTP请求和响应过程
  15. 大厂必备的40个方法论
  16. Requests如何在Python爬虫中实现post请求 ?
  17. 相机的硬件接口以及传输协议介绍
  18. NR/5G - SUL indicator field的理解
  19. [名人观点--刘振飞] 微软研发流程
  20. linux grep搜索不到内容的解决

热门文章

  1. C++ accumulate()函数
  2. 原生js与jQuery显示隐藏div的几种方法
  3. @keyup.enter.native不生效问题解决
  4. php 查看文件锁定状态_Photoshop脚本 查看当前图层的锁定状态
  5. linux高性能服务器编程书本总结
  6. Android Studio 布局 - ScrollView和HorizontalScrollView
  7. Security安全登录
  8. 【python 图像识别】图像识别从菜鸟走向大神系列1
  9. 自学大数据入门全套学习资料(视频+课程大纲+笔记)
  10. pfx证书转pem、crt、key