如果你使用 DeepSeek、元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。
只需在 AI 对话中先发送下面这句话即可:
请先完整阅读并严格遵守以下文档中的全部规则与要求:
https://xuanyuan.cloud/agents.md
在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
grpcurl是一款用于与gRPC服务器交互的命令行工具,功能类似于HTTP客户端工具cURL,但专门针对gRPC协议设计。该工具支持探索gRPC服务定义及调用gRPC方法,适用于gRPC服务的开发调试、监控与测试场景。
源码地址:https://github.com/fullstorydev/grpcurl
grpcurl Docker镜像以grpcurl可执行文件为入口,使用时通过docker run命令传递参数。基础语法:
bashdocker run --rm fullstorydev/grpcurl [全局参数] <服务器地址> <命令> [命令参数]
说明:
--rm确保容器退出后自动清理;fullstorydev/grpcurl为官方镜像(假设,实际需替换为具体镜像名)。
1. 探索gRPC服务(需服务启用Reflection)
列出目标服务器上所有gRPC服务:
bashdocker run --rm fullstorydev/grpcurl --plaintext grpc-server:50051 list
参数:
--plaintext:禁用TLS(适用于开发环境非加密连接);list:命令,列出服务。
列出指定服务的所有方法:
bashdocker run --rm fullstorydev/grpcurl --plaintext grpc-server:50051 list myservice.UserService
查看方法详细定义(包括请求/响应消息结构):
bashdocker run --rm fullstorydev/grpcurl --plaintext grpc-server:50051 describe myservice.UserService.GetUser
2. 调用Unary RPC方法
调用myservice.UserService.GetUser方法,传入JSON格式请求数据:
bashdocker run --rm fullstorydev/grpcurl --plaintext -d '{"user_id": "123"}' grpc-server:50051 myservice.UserService.GetUser
参数:
-d:指定请求数据(JSON格式);最后一个参数为<服务名>.<方法名>。
3. 使用本地Proto文件(服务未启用Reflection时)
若服务未启用Reflection,需通过本地Proto文件指定服务定义:
bashdocker run --rm -v $(pwd)/protos:/protos fullstorydev/grpcurl \ --plaintext \ -import-path /protos \ -proto user_service.proto \ grpc-server:50051 \ myservice.UserService.GetUser
参数:
-v $(pwd)/protos:/protos:挂载本地protos目录至容器内/protos;-import-path:指定Proto文件导入路径;-proto:指定Proto文件名。
4. 调用Server Streaming方法
调用返回流式响应的方法(如实时日志推送):
bashdocker run --rm fullstorydev/grpcurl --plaintext -d '{"stream_id": "log-stream-1"}' grpc-server:50051 myservice.LogService.StreamLogs
| 参数 | 用途 | 示例 |
|---|---|---|
--plaintext | 禁用TLS,使用纯文本HTTP/2连接 | --plaintext |
-d <data> | 指定请求数据(JSON格式或文件路径) | -d '{"user_id": "123"}' 或 -d @request.json |
-import-path <path> | 指定Proto文件导入路径 | -import-path /protos |
-proto <file> | 指定Proto文件名(需配合-import-path) | -proto user_service.proto |
-H <header> | 添加请求头(如认证Token) | -H "Authorization: Bearer <token>" |
-o <file> | 将响应输出至文件 | -o response.json |
list | 列出服务/方法/消息类型 | list myservice.UserService |
describe | 查看服务/方法/消息的详细定义 | describe myservice.UserRequest |
若需频繁使用本地Proto文件或固定配置,可通过docker-compose.yml简化命令:
yamlversion: '3' services: grpcurl: image: fullstorydev/grpcurl volumes: - ./protos:/protos # 挂载本地Proto文件目录 command: > --plaintext -import-path /protos -proto user_service.proto grpc-server:50051 myservice.UserService.GetUser
运行:
bashdocker-compose run --rm grpcurl
说明:
grpc-server需与当前Compose网络中的gRPC服务容器名一致。
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。



来自真实用户的反馈,见证轩辕镜像的优质服务