本站支持搜索的镜像仓库:Docker Hub、gcr.io、ghcr.io、quay.io、k8s.gcr.io、registry.gcr.io、elastic.co、mcr.microsoft.com
consul-dataplane 是 HashiCorp Consul 生态的轻量级数据平面组件,用于将应用程序无缝接入 Consul 服务网格。其核心作用是作为应用与 Consul 控制平面之间的通信桥梁,简化应用与服务网格的集成过程,实现服务发现、流量管理、安全通信等服务网格核心能力。
docker run)通过以下命令启动 consul-dataplane 容器,将应用接入 Consul 服务网格:
docker run -d \ --name=consul-dataplane \ --network=host \ # 共享主机网络(或与应用容器共享网络命名空间) hashicorp/consul-dataplane:latest \ -consul-server-addr="consul-server:8500" \ # Consul 控制平面地址 -service-name="my-app" \ # 注册的服务名称 -service-port=8080 \ # 应用监听端口 -service-meta="version=1.0" \ # 服务元数据(可选) -enable-mtls=true # 启用 mTLS 加密(可选)
关键说明:
--network=host:若应用与 dataplane 部署在同一主机,可共享网络以简化流量转发;容器化环境中建议与应用容器使用 --network=container:<app-container-id> 共享网络命名空间。-consul-server-addr:必填,指定 Consul 控制平面地址(格式:host:port,支持多个地址用逗号分隔)。-service-name 与 -service-port:必填,定义应用服务的名称和端口,用于服务注册。以下示例展示应用容器与 consul-dataplane 作为 sidecar 协同部署的 docker-compose.yml:
version: '3.8' services: my-app: image: my-app:latest # 业务应用镜像 ports: - "8080:8080" # 应用容器配置(如环境变量、挂载等) consul-dataplane: image: hashicorp/consul-dataplane:latest network_mode: "service:my-app" # 与应用容器共享网络命名空间 depends_on: - my-app command: - -consul-server-addr="consul-server:8500" - -service-name="my-app" - -service-port=8080 - -health-check-http-path="/health" # HTTP 健康检查路径(可选) - -log-level="info" # 日志级别(可选,默认 info)
说明:
network_mode: "service:my-app":确保 dataplane 与应用容器共享网络,无需额外端口映射即可拦截流量。depends_on:确保应用容器启动后再启动 dataplane。| 参数名 | 类型 | 说明 | 是否必填 |
|---|---|---|---|
-consul-server-addr | string | Consul 控制平面地址(格式:host:port,多个地址用逗号分隔) | 是 |
-service-name | string | 注册到 Consul 的服务名称 | 是 |
-service-port | int | 应用服务监听端口 | 是 |
-service-meta | string | 服务元数据(键值对格式:key=value,多个元数据用逗号分隔) | 否 |
-enable-mtls | bool | 是否启用 mTLS 加密(默认:true) | 否 |
-health-check-http-path | string | HTTP 健康检查路径(如 /health,需配合 -health-check-http-port) | 否 |
-health-check-http-port | int | 健康检查端口(默认与 -service-port 一致) | 否 |
-log-level | string | 日志级别(debug/info/warn/error,默认:info) | 否 |
支持通过环境变量传递配置(优先级低于命令行参数):
| 环境变量名 | 对应命令行参数 | 说明 |
|---|---|---|
CONSUL_SERVER_ADDR | -consul-server-addr | Consul 控制平面地址 |
SERVICE_NAME | -service-name | 服务名称 |
SERVICE_PORT | -service-port | 服务端口 |
SERVICE_META | -service-meta | 服务元数据 |
ENABLE_MTLS | -enable-mtls | 是否启用 mTLS(true/false) |
LOG_LEVEL | -log-level | 日志级别 |
--cpus=0.5 -m=256m),避免资源竞争。-log-level=debug 排查启动问题,可挂载日志目录(如 -v ./logs:/var/log/consul-dataplane)持久化日志。免费版仅支持 Docker Hub 加速,不承诺可用性和速度;专业版支持更多镜像源,保证可用性和稳定速度,提供优先客服响应。
免费版仅支持 docker.io;专业版支持 docker.io、gcr.io、ghcr.io、registry.k8s.io、nvcr.io、quay.io、mcr.microsoft.com、docker.elastic.co 等。
当返回 402 Payment Required 错误时,表示流量已耗尽,需要充值流量包以恢复服务。
通常由 Docker 版本过低导致,需要升级到 20.x 或更高版本以支持 V2 协议。
先检查 Docker 版本,版本过低则升级;版本正常则验证镜像信息是否正确。
使用 docker tag 命令为镜像打上新标签,去掉域名前缀,使镜像名称更简洁。
探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录方式配置轩辕镜像加速服务,包含7个详细步骤
在 Linux 系统上配置轩辕镜像源,支持主流发行版
在 Docker Desktop 中配置轩辕镜像加速,适用于桌面系统
在 Docker Compose 中使用轩辕镜像加速,支持容器编排
在 k8s 中配置 containerd 使用轩辕镜像加速
在宝塔面板中配置轩辕镜像加速,提升服务器管理效率
在 Synology 群晖NAS系统中配置轩辕镜像加速
在飞牛fnOS系统中配置轩辕镜像加速
在极空间NAS中配置轩辕镜像加速
在爱快ikuai系统中配置轩辕镜像加速
在绿联NAS系统中配置轩辕镜像加速
在威联通NAS系统中配置轩辕镜像加速
在 Podman 中配置轩辕镜像加速,支持多系统
配置轩辕镜像加速9大主流镜像仓库,包含详细配置步骤
无需登录即可使用轩辕镜像加速服务,更加便捷高效
需要其他帮助?请查看我们的 常见问题 或 官方QQ群: 13763429