Confluent Schema Registry compatibility API
Apicurio Registry provides a compatibility API layer that enables applications using Confluent Schema Registry clients to work seamlessly with Apicurio Registry. This chapter describes the supported features, limitations, and migration considerations.
Overview of the compatibility API
Apicurio Registry implements the Confluent Schema Registry REST API to provide drop-in compatibility for applications and tools designed for Confluent Schema Registry.
| Version | Endpoint | Status |
|---|---|---|
v7 |
|
Fully supported |
v8 |
|
Fully supported |
Applications using Confluent Schema Registry client libraries can use Apicurio Registry as a replacement by simply changing the schema registry URL to point to the appropriate Apicurio Registry ccompat endpoint.
# Confluent client configuration pointing to Apicurio Registry
schema.registry.url=http://my-registry:8080/apis/ccompat/v7
Supported features
The following Confluent Schema Registry features are fully supported in Apicurio Registry:
| Feature | Description |
|---|---|
Schemas API |
Full support for schema management including |
Subjects API |
Complete CRUD operations for subjects including listing, registration, lookup, and deletion. Supports pagination with |
Compatibility API |
Schema compatibility checking against specific versions or all versions. Supports |
Config API |
Global and subject-level compatibility configuration. Supports |
Mode API |
Global and subject-level mode management (READWRITE, READONLY, READONLY_OVERRIDE, IMPORT). Supports |
Contexts API |
Returns the default context for Confluent client compatibility. |
| Schema Type | Support Status |
|---|---|
Apache Avro |
Fully supported |
JSON Schema |
Fully supported |
Google Protobuf |
Fully supported |
| Feature | Description |
|---|---|
X-Confluent-Accept-Unknown-Properties header |
When set to |
Enhanced pagination |
Full pagination support on schemas and subjects endpoints. |
Unsupported features
The following Confluent Schema Registry features are not supported in Apicurio Registry. Applications relying on these features will need to use alternative approaches.
| Feature | Behavior | Alternative |
|---|---|---|
Schema Linking / Exporters |
|
Use Apicurio Registry native import/export functionality or external replication tools. |
KEKs (Key Encryption Keys) |
Endpoints not present (404 error). |
Implement encryption at the application layer or use external key management. |
DEKs (Data Encryption Keys) |
Endpoints not present (404 error). |
Implement encryption at the application layer or use external key management. |
Cluster Metadata API |
Endpoints |
Use Apicurio Registry system API for registry information. |
Data Contracts - Rules Enforcement |
|
Use Apicurio Registry native content rules (validity, compatibility, integrity) instead. |
Schema Linking / Exporters
Confluent Schema Linking uses schema exporters to replicate schemas between Schema Registry clusters. This is an enterprise feature that requires cluster-to-cluster replication infrastructure.
Apicurio Registry provides alternative approaches for schema replication:
-
Import/Export API: Use the Apicurio Registry admin API to export all registry content to a ZIP file and import it into another instance.
-
Kafka-based storage: When using Kafka storage, schemas are stored in a Kafka topic that can be replicated using Kafka’s native replication features.
-
GitOps workflows: Store schemas in Git and use CI/CD pipelines to sync across environments.
Data Contracts
Confluent Data Contracts provide governance features including:
-
Metadata: Key-value pairs attached to schemas (owner, email, tags)
-
RuleSets: Validation and transformation rules using CEL or JSONata
In Apicurio Registry, these fields are accepted in API requests for client compatibility but are not processed or stored. Instead, use Apicurio Registry native features:
-
Labels: Use artifact labels for metadata
-
Content Rules: Configure validity, compatibility, and integrity rules
-
Groups: Organize artifacts by group for governance
Migration considerations
When migrating from Confluent Schema Registry to Apicurio Registry, consider the following:
| Area | Consideration |
|---|---|
Basic Operations |
Schema registration, retrieval, and compatibility checks work identically. No changes required. |
Client Configuration |
Update |
Schema Types |
Avro, JSON Schema, and Protobuf are fully supported. |
Authentication |
Apicurio Registry supports OIDC authentication. Update client security configuration as needed. |
Exporters / Schema Linking |
Not supported. Use Apicurio Registry import/export API or Kafka topic replication. |
Data Contracts |
Metadata and rules are not enforced. Migrate governance to Apicurio Registry native rules. |
Encryption (KEK/DEK) |
Not supported. Implement encryption at the application layer. |
// Before: Confluent Schema Registry
Properties props = new Properties();
props.put("schema.registry.url", "http://confluent-registry:8081");
// After: Apicurio Registry (using ccompat API)
Properties props = new Properties();
props.put("schema.registry.url", "http://apicurio-registry:8080/apis/ccompat/v7");
