介绍一下Spring Cloud Stream主要概念

本文详细介绍了SpringCloud Stream的使用方法,包括创建和运行流应用程序等内容。SpringCloud Stream是一个基于Spring Boot构建的消息驱动微服务框架,提供了与消息代理的连接及中间件的配置。

本节将详细介绍如何使用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()); } } 主要概念 Spring Cloud Stream提供了一些简化了消息驱动的微服务应用程序编写的抽象和原语。本节概述了以下内容:

Spring Cloud Stream的应用模型

Binder抽象

持续的发布 - 订阅支持

消费者群体支持

分区支持

一个可插拔的Binder API

源码来源:http://minglisoft.cn/honghu/technology.html

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值