Binder SPI 由许多接口、开箱即用的实用程序类和发现策略组成,这些策略为连接到外部中间件提供了可插拔机制。
SPI的关键点是接口,它是将输入和输出连接到外部中间件的策略。以下列表显示了接口的定义:Binder
Binder
public interface Binder<T, C extends ConsumerProperties, P extends ProducerProperties> {
Binding<T> bindConsumer(String bindingName, String group, T inboundBindTarget, C consumerProperties);
Binding<T> bindProducer(String bindingName, T outboundBindTarget, P producerProperties);
}
该接口是参数化的,提供许多扩展点:
-
输入和输出绑定目标。
-
扩展使用者和生产者属性,允许特定的 Binder 实现添加可以类型安全方式支持的补充属性。
典型的 binder 实现包括以下内容:
-
实现接口的类;
Binder
-
一个 Spring 类,用于创建 Bean 类型以及中间件连接基础结构。
@Configuration
Binder
-
在包含一个或多个活页夹定义的类路径上找到的文件,如以下示例所示:
META-INF/spring.binders
kafka:\ org.springframework.cloud.stream.binder.kafka.config.KafkaBinderConfiguration
如前所述,Binder 抽象也是框架的扩展点之一。因此,如果你在前面的列表中找不到合适的活页夹,你可以在Spring Cloud Stream上实现你自己的活页夹。
在如何从头开始创建Spring Cloud Stream Binder中,发布社区成员文档
详细地,举例说明实现自定义活页夹所需的一组步骤。
该部分还突出显示了这些步骤。Implementing Custom Binders |
如前所述,Binder 抽象也是框架的扩展点之一。因此,如果你在前面的列表中找不到合适的活页夹,你可以在Spring Cloud Stream上实现你自己的活页夹。
在如何从头开始创建Spring Cloud Stream Binder中,发布社区成员文档
详细地,举例说明实现自定义活页夹所需的一组步骤。
该部分还突出显示了这些步骤。Implementing Custom Binders |