
remogloor/nginx-proxy-letsencryptacme-companion 是 nginx-proxy 的轻量级配套容器,通过ACME协议处理代理Docker容器的SSL证书自动创建、续期和使用,简化HTTPS配置流程。
http-01 挑战进行Let's Encrypt/ACME域名验证http-01挑战失败)HTTPS_METHOD=nohttp配置!架构图
nginx-proxy容器需声明三个可写卷,以便与acme-companion共享:
/etc/nginx/certs:存储证书和私钥(nginx-proxy容器为只读)/etc/nginx/vhost.d:修改虚拟主机配置(CA需访问http-01挑战文件)/usr/share/nginx/html:写入http-01挑战文件acme-companion容器需额外声明一个卷:/etc/acme.sh,用于存储acme.sh配置和状态。
启动nginx-proxy容器并声明所需卷:
shell$ docker run --detach \ --name nginx-proxy \ --publish 80:80 \ --publish 443:443 \ --volume certs:/etc/nginx/certs \ --volume vhost:/etc/nginx/vhost.d \ --volume html:/usr/share/nginx/html \ --volume /var/run/docker.sock:/tmp/docker.sock:ro \ nginxproxy/nginx-proxy
注:必须将主机的Docker socket(
/var/run/docker.sock)挂载到容器内的/tmp/docker.sock,这是nginx-proxy的必要配置。
通过--volumes-from继承nginx-proxy的卷,并启动acme-companion:
shell$ docker run --detach \ --name nginx-proxy-acme \ --volumes-from nginx-proxy \ --volume /var/run/docker.sock:/var/run/docker.sock:ro \ --volume acme:/etc/acme.sh \ --env "DEFAULT_EMAIL=***" \ nginxproxy/acme-companion
注:
- 需将主机Docker socket挂载到容器内的
/var/run/docker.sock- 建议通过
DEFAULT_EMAIL环境变量提供有效***,Let's Encrypt会通过该***发送证书过期提醒及账户恢复信息
当nginx-proxy和acme-companion容器运行后,启动需代理的容器时,需设置以下环境变量:
VIRTUAL_HOST:控制nginx-proxy的代理配置LETSENCRYPT_HOST:控制acme-companion的证书创建和SSL启用证书仅会为同时设置了VIRTUAL_HOST和LETSENCRYPT_HOST,且域名正确解析到主机的容器颁发。
shell$ docker run --detach \ --name your-proxied-app \ --env "VIRTUAL_HOST=subdomain.yourdomain.tld" \ --env "LETSENCRYPT_HOST=subdomain.yourdomain.tld" \ nginx
shell$ docker run --detach \ --name grafana \ --env "VIRTUAL_HOST=othersubdomain.yourdomain.tld" \ --env "VIRTUAL_PORT=3000" # 指定容器暴露的端口 --env "LETSENCRYPT_HOST=othersubdomain.yourdomain.tld" \ --env "LETSENCRYPT_EMAIL=***" # 可覆盖DEFAULT_EMAIL grafana/grafana
注:被代理容器必须暴露需代理的端口,可通过Dockerfile的
EXPOSE指令或docker run的--expose参数实现。
更多详细文档请参考 项目文档目录。
探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录认证访问私有仓库
无需登录使用专属域名
Kubernetes 集群配置 Containerd
K3s 轻量级 Kubernetes 镜像加速
VS Code Dev Containers 配置
Podman 容器引擎配置
HPC 科学计算容器配置
ghcr、Quay、nvcr 等镜像仓库
Harbor Proxy Repository 对接专属域名
Portainer Registries 加速拉取
Nexus3 Docker Proxy 内网缓存
需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单
manifest unknown
no matching manifest(架构)
TLS 证书失败
DNS 超时
410 Gone 排查
402 与流量用尽
401 认证失败
429 限流
D-Bus 凭证提示
413 与超大单层
来自真实用户的反馈,见证轩辕镜像的优质服务