第 4 章 使用 REST API 管理 Service Registry 内容
客户端应用程序可以使用 Registry REST API 操作来管理 Service Registry 中的 schema 和 API 工件,例如在生产环境中部署的 CI/CD 管道中。Registry REST API 为存储在 registry 中的工件、版本、元数据和规则提供创建、读取、更新和删除操作。如需更多信息,请参阅 Apicurio Registry REST API 文档。
本章论述了 Service Registry core REST API,并演示了如何使用它来管理 registry 中存储的模式和 API 工件:
4.1. 使用 Service Registry REST API 命令管理 schema 和 API 工件
本节演示了一个简单的基于 curl 的示例,它使用了 Service Registry 核心 REST API 在 Service Registry 中添加和检索 Apache Avro schema 工件。
先决条件
- Service Registry 在您的环境中安装并运行
流程
使用
/groups/{group}/artifacts
操作向 registry 添加工件。以下示例curl
命令为共享价格应用程序添加一个简单的工件:$ curl -X POST -H "Content-Type: application/json; artifactType=AVRO" \ -H "X-Registry-ArtifactId: share-price" \ -H "Authorization: Bearer $ACCESS_TOKEN" \ --data '{"type":"record","name":"price","namespace":"com.example", \ "fields":[{"name":"symbol","type":"string"},{"name":"price","type":"string"}]}' \ MY-REGISTRY-URL/apis/registry/v2/groups/my-group/artifacts
-
这个示例添加了一个 Avro schema 工件 ID,其工件 ID 为
share-price
。如果没有指定唯一的工件 ID,Service Registry 会自动生成一个 UUID。 -
MY-REGISTRY-URL
是在其上部署 Service Registry 的主机名。例如:my-cluster-service-registry-myproject.example.com
。 -
本例在 API 路径中指定
my-group
的组 ID。如果没有指定唯一组 ID,则必须在 API 路径中指定../groups/default
。
-
这个示例添加了一个 Avro schema 工件 ID,其工件 ID 为
验证响应是否包含预期的 JSON 正文,以确认工件已被添加。例如:
{"createdBy":"","createdOn":"2021-04-16T09:07:51+0000","modifiedBy":"", "modifiedOn":"2021-04-16T09:07:51+0000","id":"share-price","version":"1", "type":"AVRO","globalId":2,"state":"ENABLED","groupId":"my-group","contentId":2}
-
在添加工件时没有指定版本,因此会自动创建默认版本
1
。 -
这是添加到 registry 的第二个工件,因此全局 ID 和内容 ID 的值为
2
。
-
在添加工件时没有指定版本,因此会自动创建默认版本
在 API 路径中使用其工件 ID 从 registry 检索工件内容。在这个示例中,指定的 ID 是 shared
-price
:$ curl -H "Authorization: Bearer $ACCESS_TOKEN" \ MY-REGISTRY-URL/apis/registry/v2/groups/my-group/artifacts/share-price \ {"type":"record","name":"price","namespace":"com.example", "fields":[{"name":"symbol","type":"string"},{"name":"price","type":"string"}]}
其他资源
- 如需更多 REST API 示例请求,请参阅 Apicurio Registry REST API 文档