OCI Registry MCP 服务器是一个基于 MCP(模型上下文协议)的服务器,它提供了用于查询 OCI 注册表和镜像引用的工具,能让基于大语言模型的应用与 OCI 注册表进行交互。
本项目实现了一个基于 SSE 的 MCP 服务器,允许由大语言模型驱动的应用程序与 OCI 注册表进行交互。它提供了检索容器镜像信息、列出标签等工具。
服务器提供了以下 MCP 工具:
获取 OCI 镜像的信息。 输入:
image_ref:镜像引用(例如:docker.io/library/alpine:latest)
输出:列出仓库的标签。 输入:
repository:仓库名称(例如:docker.io/library/alpine)
输出:获取 OCI 镜像的清单。 输入:
image_ref:镜像引用(例如:docker.io/library/alpine:latest)
输出:获取 OCI 镜像的配置。 输入:
image_ref:镜像引用(例如:docker.io/library/alpine:latest)
输出:运行 OCI Registry MCP 服务器最简单的方法是使用 ToolHive,它提供了 MCP 服务器的安全、容器化部署:
# 安装 ToolHive(如果尚未安装)
# 请参阅:https://github.com/stacklok/toolhive#installation
# 启用自动发现以自动配置受支持的客户端
thv config auto-discovery true
# 运行 OCI Registry MCP 服务器(在 ToolHive 中打包为 'oci-registry')
thv run oci-registry
# 列出正在运行的服务器
thv list
# 获取服务器的详细信息
thv registry info oci-registry
服务器将对与 MCP 兼容的客户端可用,并可以查询 OCI 注册表以获取镜像信息。
如果需要访问私有注册表,可以使用 ToolHive 的密钥管理提供身份验证凭据:
# 对于令牌身份验证
thv secret set oci-token
# 提示时输入令牌
thv run --secret oci-token,target=OCI_TOKEN oci-registry
# 对于用户名/密码身份验证
thv secret set oci-username
thv secret set oci-password
# 提示时输入凭据
thv run --secret oci-username,target=OCI_USERNAME --secret oci-password,target=OCI_PASSWORD oci-registry
服务器支持以下用于访问私有 OCI 注册表的身份验证方法:
OCI_TOKEN:用于注册表身份验证的令牌OCI_USERNAME:用于注册表身份验证的用户名OCI_PASSWORD:用于注册表身份验证的密码~/.docker/config.json 读取凭据。
示例:# 令牌身份验证
export OCI_TOKEN=mytoken
# 用户名/密码身份验证
export OCI_USERNAME=myuser
export OCI_PASSWORD=mypassword
可以使用以下两种方式之一将服务器配置为监听特定端口:
MCP_PORT:要监听的端口号(必须在 0 到 65535 之间)-port:覆盖环境变量设置(必须在 0 到 65535 之间)./ocireg-mcp -port 9090go test ./...
golangci-lint run
我们欢迎对这个 MCP 服务器做出贡献!如果您想贡献代码,请查看 贡献指南 以了解如何开始。
如果您遇到了 bug 或有功能请求,请在 仓库 中 创建一个问题,或者加入我们 社区 Discord 服务器 的 #mcp-servers 频道。
本项目采用 Apache v2 许可证 - 详情请参阅 LICENSE 文件。