本站支持搜索的镜像仓库:Docker Hub、gcr.io、ghcr.io、quay.io、k8s.gcr.io、registry.gcr.io、elastic.co、mcr.microsoft.com

镜像名称:certbot/dns-google
官方版本:v1.7.0
维护方:Electronic Frontier Foundation (EFF)
本镜像为Certbot的官方Docker镜像之一,集成了Google Cloud DNS插件,用于通过Google Cloud DNS服务执行DNS-01挑战,自动化获取和续期Let's Encrypt等证书颁发机构的SSL/TLS证书。镜像基于Certbot核心构建,专注于解决无法通过HTTP-01挑战(如防火墙限制、非公开服务器场景)的证书申请需求。
*.example.com),仅DNS-01挑战支持。Google Cloud平台准备:
DNS Administrator(或自定义角色,包含dns.resourceRecordsSets.create、dns.resourceRecordsSets.delete权限)。/local/path/to/credentials.json)。Docker环境:已安装Docker Engine(20.10+推荐)或Docker Compose。
通过Docker Hub拉取官方镜像:
docker pull certbot/dns-google:v1.7.0
以下命令通过Google Cloud DNS插件申请域名证书,将证书存储在本地./certbot目录,并挂载GCP凭证文件:
docker run -it --rm \ -v /local/path/to/certbot:/etc/letsencrypt \ # 持久化证书存储目录 -v /local/path/to/credentials.json:/etc/google/credentials.json:ro \ # 挂载GCP凭证(只读) certbot/dns-google:v1.7.0 \ certonly \ # 仅申请证书(不安装) --dns-google \ # 指定使用Google Cloud DNS插件 --dns-google-credentials /etc/google/credentials.json \ # 插件使用的凭证文件路径(容器内路径) --dns-google-project "your-gcp-project-id" \ # GCP项目ID(可选,凭证文件中已包含时可省略) --agree-tos \ # 同意Let's Encrypt服务条款 --email "***" \ # 管理员邮箱(用于证书到期通知) --domains "example.com" \ # 目标域名(支持多个,用逗号分隔) --non-interactive # 非交互式运行(适合自动化)
Certbot默认会自动续期即将过期(剩余30天内)的证书,可通过以下命令手动触发续期:
docker run -it --rm \ -v /local/path/to/certbot:/etc/letsencrypt \ -v /local/path/to/credentials.json:/etc/google/credentials.json:ro \ certbot/dns-google:v1.7.0 \ renew \ # 续期命令 --dns-google \ --dns-google-credentials /etc/google/credentials.json \ --non-interactive
创建docker-compose.yml,定义证书申请服务:
version: '3.8' services: certbot-dns-google: image: certbot/dns-google:v1.7.0 volumes: - ./certbot:/etc/letsencrypt # 本地证书存储 - ./gcp-credentials.json:/etc/google/credentials.json:ro # GCP凭证文件 command: > certonly --dns-google --dns-google-credentials /etc/google/credentials.json --dns-google-project "your-gcp-project-id" --agree-tos --email "***" --domains "example.com,*.example.com" --non-interactive restart: "no" # 证书申请为一次性任务,无需持续运行
启动服务(首次申请证书):
docker-compose up
| 参数 | 说明 |
|---|---|
certonly | 仅申请证书,不自动安装到Web服务器。 |
renew | 续期所有符合条件的证书(默认剩余30天内)。 |
--domains | 目标域名,多个域名用逗号分隔(如example.com,*.example.com)。 |
--email | 管理员邮箱,用于证书到期通知及紧急恢复。 |
--agree-tos | 自动同意Let's Encrypt服务条款(非交互式必需)。 |
--non-interactive | 非交互式模式,适合脚本或自动化场景(无手动确认步骤)。 |
--test-cert | 使用Let's Encrypt测试环境(避免生产环境速率限制,测试时推荐)。 |
| 参数 | 说明 |
|---|---|
--dns-google | 启用Google Cloud DNS插件(必需)。 |
--dns-google-credentials | GCP服务账号凭证文件路径(容器内路径,需通过-v挂载本地文件)。 |
--dns-google-project | GCP项目ID(可选,若凭证文件中已包含项目ID,可省略)。 |
--dns-google-propagation-seconds | DNS记录传播等待时间(秒,默认60秒,复杂DNS环境可增加)。 |
| 环境变量 | 说明 |
|---|---|
GOOGLE_APPLICATION_CREDENTIALS | 替代--dns-google-credentials参数,指定凭证文件路径(容器内路径)。 |
免费版仅支持 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