
https://github.com/domnikl/schema-registry-gitops/workflows/build/badge.svg](https://github.com/domnikl/schema-registry-gitops/actions)
通过应用期望状态文件,管理Confluent Schema Registry的主题、兼容性级别和模式注册。
Schema Registry GitOps是一款基础设施即代码工具,通过简单的YAML和Avro/Protobuf/JSON Schema文件配置期望状态,并将其应用到模式注册表。可保留模式的版本控制历史,在CI/CD pipeline中使用常用工具验证、审查、合并和演进模式。
!https://raw.githubusercontent.com/domnikl/schema-registry-gitops/main/schema-registry-gitops.svg
Usage: schema-registry-gitops [-hvV] [--properties=<propertiesFilePath>] [-r=<baseUrl>] [COMMAND] 通过基础设施即代码管理模式注册表 -h, --help 显示帮助信息并退出 --properties=<propertiesFilePath> 客户端配置的Java Properties文件(可选) -r, --registry=<baseUrl> 模式注册表端点,覆盖properties中的'schema.registry.url',可指定逗号分隔的多个URL -v, --verbose 启用详细日志 -V, --version 打印版本信息并退出 命令: apply 将状态应用到指定的模式注册表 dump 打印当前状态 plan 验证并计划模式变更,查看所有待执行变更
查看特定命令帮助:schema-registry-gitops <命令> -h
通过https://hub.docker.com/repository/docker/domnikl/schema-registry-gitops%E8%8E%B7%E5%8F%96%E9%95%9C%E5%83%8F%EF%BC%8C%E7%A4%BA%E4%BE%8B%EF%BC%9A
sh# 计划变更(查看待应用内容) docker run -v "$(pwd)/examples":/data domnikl/schema-registry-gitops plan --properties /data/client.properties /data/base.yml # 应用变更 docker run -v "$(pwd)/examples":/data domnikl/schema-registry-gitops apply --registry http://schema-registry:8081 /data/base.yml # 导出当前状态 docker run -v "$(pwd)/output":/data domnikl/schema-registry-gitops dump --registry http://schema-registry:8081 > /data/current_state.yml
建议使用标签版本(如:v1.0.0)确保稳定性。
通过YAML定义期望状态,支持多文件合并(后定义主题覆盖同名先定义主题)。示例:
yaml# 全局兼容性级别(可选) compatibility: FULL_TRANSITIVE subjects: # 引用外部文件的主题 - name: my-new-subject-referencing-a-schema-file compatibility: BACKWARD # 主题级兼容性(可选,覆盖全局) file: my-actual-schema.avsc # 路径相对于当前YAML type: AVRO # 模式类型(默认AVRO,≥5.5支持PROTOBUF/JSON) references: # 模式引用(可选) - name: dev.domnikl.schema-registry-gitops.User # 引用名称(含命名空间) subject: User-value # 被引用模式的主题名 version: 1 # 被引用模式版本 # 内联模式的主题(Protobuf示例) - name: my-new-inline-schema-subject schema: 'syntax = "proto3"; package com.acme; message OtherRecord { int32 an_id = 1; }' type: PROTOBUF
兼容性级别
支持值:NONE、FORWARD、BACKWARD、FULL、FORWARD_TRANSITIVE、BACKWARD_TRANSITIVE、FULL_TRANSITIVE
模式定义方式
file:外部模式文件路径(相对当前YAML)schema:内联模式字符串(二选一,推荐使用file)Properties文件配置
通过Java Properties文件配置客户端,示例(含SSL):
propertiesschema.registry.url=https://localhost:8081 security.protocol=SSL schema.registry.ssl.truststore.location=truststore.jks schema.registry.ssl.truststore.password=<secret> schema.registry.ssl.keystore.location=keystore.jks schema.registry.ssl.keystore.password=<secret> schema.registry.ssl.key.password=<secret>
使用--properties参数指定文件:
shdocker run -v "$(pwd)/config":/config domnikl/schema-registry-gitops apply --properties /config/client.properties /config/state.yml
环境变量配置
支持前缀SCHEMA_REGISTRY_GITOPS_的环境变量,覆盖Properties配置。示例:
shexport SCHEMA_REGISTRY_GITOPS_SCHEMA_REGISTRY_URL=https://localhost:8081 export SCHEMA_REGISTRY_GITOPS_SECURITY_PROTOCOL=SSL export SCHEMA_REGISTRY_GITOPS_SCHEMA_REGISTRY_SSL_TRUSTSTORE_LOCATION=truststore.jks export SCHEMA_REGISTRY_GITOPS_SCHEMA_REGISTRY_SSL_TRUSTSTORE_PASSWORD=<secret>
Docker传递环境变量:
shdocker run -e SCHEMA_REGISTRY_GITOPS_SCHEMA_REGISTRY_URL=http://schema-registry:8081 -v "$(pwd)/examples":/data domnikl/schema-registry-gitops plan /data/base.yml
默认不删除状态文件中未列出但注册表存在的主题。如需完全同步(删除未列出主题),在plan/apply中使用-d或--enable-deletes:
shdocker run -v "$(pwd)/examples":/data domnikl/schema-registry-gitops apply -d --registry http://localhost:8081 /data/base.yml
使用Docker构建和测试:
sh# 构建镜像 docker build -t domnikl/schema-registry-gitops . # 运行测试 docker run -v ./examples:/data domnikl/schema-registry-gitops plan --registry http://localhost:8081 /data/base.yml /data/with_references.yml
灵感源自https://github.com/devshawn%E7%9A%84https://github.com/devshawn/kafka-gitops%E3%80%82%E6%84%9F%E8%B0%A2Confluent%E5%BC%80%E5%8F%91Schema Registry及客户端库。
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。



探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录认证访问私有仓库
无需登录使用专属域名
Kubernetes 集群配置 Containerd
K3s 轻量级 Kubernetes 镜像加速
VS Code Dev Containers 配置
Podman 容器引擎配置
HPC 科学计算容器配置
ghcr、Quay、nvcr 等镜像仓库
Harbor Proxy Repository 对接专属域名
Portainer Registries 加速拉取
Nexus3 Docker Proxy 内网缓存
需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单
docker search 限制
站内搜不到镜像
离线 save/load
插件要用 plugin install
WSL 拉取慢
安全与 digest
新手拉取配置
镜像合规机制
manifest unknown
no matching manifest(架构)
invalid tar header(解压)
TLS 证书失败
DNS 超时
域名连通性排查
410 Gone 排查
402 与流量用尽
401 认证失败
429 限流
D-Bus 凭证提示
413 与超大单层
来自真实用户的反馈,见证轩辕镜像的优质服务