SchemaRegistryException data schema_error ai_generated partial

Avro序列化失败,SchemaRegistryException:不兼容的schema版本

Avro serialization fails with SchemaRegistryException: incompatible schema version

ID: data/avro-schema-registry-serialization-version-mismatch

其他格式: JSON · Markdown 中文 · English
82%修复率
87%置信度
1证据数
2023-11-05首次发现

版本兼容性

版本状态引入弃用备注
Confluent Platform 7.5 active
Confluent Platform 7.6 active
Apache Kafka 3.5 active
Apache Kafka 3.6 active

根因分析

Confluent Schema Registry强制执行兼容性规则(BACKWARD、FORWARD、FULL),并拒绝违反配置策略的schema演进,通常因为删除字段或更改类型导致破坏现有消费者。

English

The Confluent Schema Registry enforces compatibility rules (BACKWARD, FORWARD, FULL) and rejects schema evolution that violates the configured policy, often due to removing fields or changing types in a way that breaks existing consumers.

generic

官方文档

https://docs.confluent.io/platform/current/schema-registry/avro.html

解决方案

  1. Temporarily set compatibility to BACKWARD_TRANSITIVE for the subject, register the new schema, then revert to original policy: `curl -X PUT -H 'Content-Type: application/vnd.schemaregistry.v1+json' -d '{"compatibility": "BACKWARD_TRANSITIVE"}' https://registry:8081/config/subject-name`
  2. Add the new field with a default value to maintain backward compatibility: `{"name": "new_field", "type": "string", "default": ""}`
  3. Use FULL_TRANSITIVE compatibility and register a new version that adds fields with defaults and removes no fields

无效尝试

常见但无效的做法:

  1. 85% 失败

    Schema Registry does not allow deletion of schemas that have been used; you must use soft delete or wait for the cleanup policy.

  2. 70% 失败

    This creates a new subject that existing consumers are not subscribed to, breaking data flow and requiring manual topic reconfiguration.

  3. 60% 失败

    Disabling compatibility entirely allows any schema change, which can silently break downstream consumers and cause production incidents.