7.2. 在 Service Registry 中查找模式的策略
Kafka 客户端序列化器使用 lookup 策略来 决定在 Service Registry 中注册消息模式的工件 ID 和全局 ID。对于给定主题和消息,您可以使用 ArtifactReferenceResolverStrategy
Java 接口的不同实现来返回对 registry 中工件的引用。
每个策略的类位于 io.apicurio.registry.serde.strategy
软件包中。Avro SerDes 的特定策略类位于 io.apicurio.registry.serde.avro.strategy 软件包中
。默认策略是 TopicIdStrategy
,它查找名称与接收消息的 Kafka 主题相同的 Service Registry 工件。
示例
public ArtifactReference artifactReference(String topic, boolean isKey, T schema) { return ArtifactReference.builder() .groupId(null) .artifactId(String.format("%s-%s", topic, isKey ? "key" : "value")) .build();
-
topic
参数是接收消息的 Kafka 主题的名称。 -
当 message 键被序列化时,
isKey
参数为true
,当 message 值被序列化时为false
。 -
schema
参数是消息序列化或反序列化的 schema。 -
ArtifactReference
返回包含注册 schema 的工件 ID。
您使用的查找策略取决于您如何和存储模式。例如,如果您具有相同 Avro 消息类型的不同 Kafka 主题,您可以使用使用 记录 ID 的策略。
工件解析器策略
工件解析器策略提供了一种将 Kafka 主题和消息信息映射到 Service Registry 中的工件的方法。映射的常见约定是将 Kafka 主题名称与 键或
值
组合,具体取决于是否将序列化器用于 Kafka 消息键或值。
但是,您可以使用 Service Registry 提供的策略或创建一个实现 io.apicurio.registry.serde.strategy.ArtifactReferenceResolverStrategy
的自定义 Java 类来对映射使用替代惯例。
返回对工件的引用的策略
Service Registry 提供以下策略,根据 ArtifactReferenceResolverStrategy
的实现返回对工件的引用:
RecordIdStrategy
- 使用模式全名的 avro 特定策略。
TopicRecordIdStrategy
- 特定于 avro 的策略,它使用主题名称和模式的完整名称。
TopicIdStrategy
-
默认策略,它使用主题名和
key
或value
后缀。 SimpleTopicIdStrategy
- 仅使用主题名称的简单策略。
DefaultSchemaResolver 接口
默认 schema 解析器会找到并标识在由工件解析器策略提供的工件引用下注册的 schema 的特定版本。每个工件的每个版本都有一个全局唯一标识符,可用于检索该工件的内容。这个全局 ID 都包含在每个 Kafka 信息中,以便反序列化器可以正确地从 Apicurio Registry 获取 schema。
默认模式解析器可以查找现有的工件版本,如果未找到,它可以根据使用哪个策略进行注册。您还可以通过创建一个实现 io.apicurio.registry.resolver.SchemaResolver
的自定义 Java 类来提供自己的策略。但是,建议您使用 DefaultSchemaResolver
并指定配置属性。
registry 查找选项的配置
使用 DefaultSchemaResolver
时,您可以使用应用属性配置其行为。下表显示了一些常用的示例:
属性 | 类型 | 描述 | 默认 |
---|---|---|---|
|
| 指定 serializer 是否尝试在 registry 中查找对应组 ID 和工件 ID 的最新工件。 |
|
|
| 指示序列化器将指定的 ID 写入 Kafka,并指示反序列化器使用此 ID 来查找 schema。 | None |
|
| 指定 serializer 是否尝试在 registry 中创建工件。JSON 架构序列化器不支持此功能。 |
|
|
| 指定缓存全局 ID 以毫秒为单位的时间。如果没有配置,则会每次获取全局 ID。 | None |