Avro序列化失败,SchemaRegistryException:不兼容的schema版本
Avro serialization fails with SchemaRegistryException: incompatible schema version
ID: data/avro-schema-registry-serialization-version-mismatch
版本兼容性
| 版本 | 状态 | 引入 | 弃用 | 备注 |
|---|---|---|---|---|
| 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.
官方文档
https://docs.confluent.io/platform/current/schema-registry/avro.html解决方案
-
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` -
Add the new field with a default value to maintain backward compatibility: `{"name": "new_field", "type": "string", "default": ""}` -
Use FULL_TRANSITIVE compatibility and register a new version that adds fields with defaults and removes no fields
无效尝试
常见但无效的做法:
-
85% 失败
Schema Registry does not allow deletion of schemas that have been used; you must use soft delete or wait for the cleanup policy.
-
70% 失败
This creates a new subject that existing consumers are not subscribed to, breaking data flow and requiring manual topic reconfiguration.
-
60% 失败
Disabling compatibility entirely allows any schema change, which can silently break downstream consumers and cause production incidents.