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

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类型 具体参考

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

相关文章:

  • 实现Kubernetes跨集群服务应用的高可用
  • scss rem 转换函数
  • 30K iOS程序员的简述:如何快速进阶成为高级开发人员
  • sysbench安装配置和参数说明
  • Q680 验证回文字符串 Ⅱ
  • python基础知识-12-模块的了解
  • 20175318 2018-2019-2 实验二《Java面向对象程序设计》实验报告
  • 数据可视化之下发图实践
  • PCB单双面板打样工程费跨入30元时代!
  • DLC 基本定律与规则2
  • Netty源码分析(六):SelectedSelectionKeySetSelector
  • 003-Java技术体系
  • vue的事件对象,方法执行
  • CAD图纸转换成高质量的彩色PDF格式如何操作?
  • 光伏工商业屋顶 Lora 组网监控方案
  • hexo+github搭建个人博客
  • [NodeJS] 关于Buffer
  • Docker 笔记(2):Dockerfile
  • Docker入门(二) - Dockerfile
  • Java小白进阶笔记(3)-初级面向对象
  • leetcode388. Longest Absolute File Path
  • Mithril.js 入门介绍
  • mysql innodb 索引使用指南
  • node入门
  • python 装饰器(一)
  • spark本地环境的搭建到运行第一个spark程序
  • Swift 中的尾递归和蹦床
  • web标准化(下)
  • 阿里云容器服务区块链解决方案全新升级 支持Hyperledger Fabric v1.1
  • 浮现式设计
  • 观察者模式实现非直接耦合
  • 基于webpack 的 vue 多页架构
  • 力扣(LeetCode)22
  • 设计模式(12)迭代器模式(讲解+应用)
  • 项目管理碎碎念系列之一:干系人管理
  • 一、python与pycharm的安装
  • 以太坊客户端Geth命令参数详解
  • 国内唯一,阿里云入选全球区块链云服务报告,领先AWS、Google ...
  • ​你们这样子,耽误我的工作进度怎么办?
  • ​软考-高级-系统架构设计师教程(清华第2版)【第20章 系统架构设计师论文写作要点(P717~728)-思维导图】​
  • $.type 怎么精确判断对象类型的 --(源码学习2)
  • (2015)JS ES6 必知的十个 特性
  • (pytorch进阶之路)CLIP模型 实现图像多模态检索任务
  • (经验分享)作为一名普通本科计算机专业学生,我大学四年到底走了多少弯路
  • (转)母版页和相对路径
  • ..回顾17,展望18
  • .mat 文件的加载与创建 矩阵变图像? ∈ Matlab 使用笔记
  • .Net Core 中间件验签
  • .NET Core使用NPOI导出复杂,美观的Excel详解
  • .NET Standard / dotnet-core / net472 —— .NET 究竟应该如何大小写?
  • .net 受管制代码
  • .NET6实现破解Modbus poll点表配置文件
  • .NET设计模式(7):创建型模式专题总结(Creational Pattern)
  • /3GB和/USERVA开关
  • @autowired注解作用_Spring Boot进阶教程——注解大全(建议收藏!)