自 1.1 以来 1.2 中的新增功能
本节介绍从版本 1.1 到版本 1.2 所做的更改。
自定义对象映射器
你可以提供自己的 Jackson,Pulsar 在生成和使用 JSON 消息时将使用该 Jackson。
有关更多详细信息,请参阅 Custom Object Mapper 。ObjectMapper
默认租户和Namespace
您可以指定在针对非完全限定主题 URL 生成或使用消息时要使用的默认租户和/或命名空间。 有关更多详细信息,请参阅 Default Tenant / Namespace 。
消息容器启动策略
您现在可以将消息侦听器容器启动失败策略配置为 、 或 。
有关更多详细信息,请参阅受支持的容器之一 @PulsarListener、@PulsarReader 或 @ReactivePulsarListener 的相应部分stop
continue
retry
消息容器工厂定制器 (Spring Boot)
Spring Boot 引入了一个通用的消息容器工厂定制器,可用于进一步配置一个或多个自动配置的容器工厂,这些工厂支持以下侦听器注释:org.springframework.boot.autoconfigure.pulsar.PulsarContainerFactoryCustomizer<T extends PulsarContainerFactory<?, ?>>
-
要注册一个或多个 PulsarContainerFactoryCustomizer<ConcurrentPulsarListenerContainerFactory<?>> bean。
@PulsarListener
-
要注册一个或多个 PulsarContainerFactoryCustomizer<DefaultPulsarReaderContainerFactory<?>> bean。
@PulsarReader
-
要注册一个或多个 PulsarContainerFactoryCustomizer<DefaultReactivePulsarListenerContainerFactory<>> bean。
@ReactivePulsarListener
弃用
PulsarClient#getPartitionsForTopic(java.lang.String)
版本 Pulsar 客户端弃用了 ,转而使用 .3.3.1
getPartitionsForTopic(java.lang.String)
getPartitionsForTopic(java.lang.String, boolean metadataAutoCreationEnabled)
PulsarTopic#构建器
使用 Spring Boot 时,它现在是一个已注册的 Bean,它配置了 domain、tenant 和 namespace 的默认值。
因此,如果您使用的是 Spring Boot,则只需在需要时注入构建器即可。
否则,请直接使用其中一个构造函数。PulsarTopicBuilder
PulsarTopicBuilder
侦听器/ReaderContainerFactory
引入通用接口是为了弥合侦听器和阅读器容器工厂之间的差距。
作为其中的一部分,以下 API 已被弃用、复制和重命名:PulsarContainerFactory
-
ListenerContainerFactory#createListenerContainer
替换为ListenerContainerFactory#createRegisteredContainer
-
ReaderContainerFactory#createReaderContainer(E endpoint)
替换为ReaderContainerFactory#createRegisteredContainer
-
ReaderContainerFactory#createReaderContainer(String… topics)
替换为ReaderContainerFactory#createContainer
ConcurrentPulsarListenerContainerFactoryCustomizer
其目的是自定义 Spring Boot 自动配置的消息容器工厂。
但是, Spring Boot 引入了一个通用的消息容器工厂定制器,它消除了对这个定制器的需求。ConcurrentPulsarListenerContainerFactoryCustomizer
org.springframework.boot.autoconfigure.pulsar.PulsarContainerFactoryCustomizer<T extends PulsarContainerFactory<?, ?>>
将所有 的实例替换为 。ConcurrentPulsarListenerContainerFactoryCustomizer
org.springframework.boot.autoconfigure.pulsar.PulsarContainerFactoryCustomizer<ConcurrentPulsarListenerContainerFactoryCustomizer<?>>
清除
以下以前弃用的侦听器终端节点适配器已被删除,以支持侦听器终端节点接口中的默认方法:
-
org.springframework.pulsar.config.PulsarListenerEndpointAdapter
-
org.springframework.pulsar.reactive.config.ReactivePulsarListenerEndpointAdapter
自 1.0 以来 1.1 中的新增功能
本节介绍从版本 1.0 到版本 1.1 所做的更改。
自动架构支持
如果无法提前知道某个 Pulsar 主题的 schema,你可以使用 AUTO Schemas 向 broker 生成/消费泛型记录。 有关更多详细信息,请参阅使用 AUTO_SCHEMA 生产和使用 AUTO_SCHEMA。
虽然上述链接侧重于 和 ,但 、 和 也支持此功能。
每个选项的详细信息可以在本参考指南的相应部分中找到。PulsarTemplate @PulsarListener ReactivePulsarTemplate @ReactivePulsarListener @PulsarReader |
删除选中的异常
框架提供的 API 不再抛出 checked ,而是抛出 unchecked 。PulsarClientException
PulsarException
如果您以前只是为了安抚编译器而捕获或重新引发,并且实际上并没有处理异常,则只需删除 or 子句即可。
如果您实际上是在处理异常,则需要在 catch 子句中替换 。PulsarClientException catch throws PulsarClientException PulsarException |
测试支持
该模块现在可用于帮助测试 Spring for Apache Pulsar 应用程序。
有关更多详细信息,请参阅测试应用程序。spring-pulsar-test
虽然上述链接侧重于 和 ,但 、 和 也支持此功能。
每个选项的详细信息可以在本参考指南的相应部分中找到。PulsarTemplate @PulsarListener ReactivePulsarTemplate @ReactivePulsarListener @PulsarReader |
如果您以前只是为了安抚编译器而捕获或重新引发,并且实际上并没有处理异常,则只需删除 or 子句即可。
如果您实际上是在处理异常,则需要在 catch 子句中替换 。PulsarClientException catch throws PulsarClientException PulsarException |