Avro serialization fails with SchemaRegistryException: incompatible schema version
ID: data/avro-schema-registry-serialization-version-mismatch
Version Compatibility
| Version | Status | Introduced | Deprecated | Notes |
|---|---|---|---|---|
| Confluent Platform 7.5 | active | — | — | — |
| Confluent Platform 7.6 | active | — | — | — |
| Apache Kafka 3.5 | active | — | — | — |
| Apache Kafka 3.6 | active | — | — | — |
Root Cause
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中文
Confluent Schema Registry强制执行兼容性规则(BACKWARD、FORWARD、FULL),并拒绝违反配置策略的schema演进,通常因为删除字段或更改类型导致破坏现有消费者。
Official Documentation
https://docs.confluent.io/platform/current/schema-registry/avro.htmlWorkarounds
-
85% success 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`
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` -
90% success Add the new field with a default value to maintain backward compatibility: `{"name": "new_field", "type": "string", "default": ""}`
Add the new field with a default value to maintain backward compatibility: `{"name": "new_field", "type": "string", "default": ""}` -
88% success Use FULL_TRANSITIVE compatibility and register a new version that adds fields with defaults and removes no fields
Use FULL_TRANSITIVE compatibility and register a new version that adds fields with defaults and removes no fields
中文步骤
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
Dead Ends
Common approaches that don't work:
-
85% fail
Schema Registry does not allow deletion of schemas that have been used; you must use soft delete or wait for the cleanup policy.
-
70% fail
This creates a new subject that existing consumers are not subscribed to, breaking data flow and requiring manual topic reconfiguration.
-
60% fail
Disabling compatibility entirely allows any schema change, which can silently break downstream consumers and cause production incidents.