
如果你使用 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 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
本Docker镜像基于https://hub.docker.com/r/lucaslorentz/caddy-docker-proxy%E7%9A%84Caddy-Docker-Proxy%E9%95%9C%E5%83%8F%E6%9E%84%E5%BB%BA%EF%BC%8C%E9%A2%9D%E5%A4%96%E9%9B%86%E6%88%90%E4%BA%86https://github.com/caddy-dns/cloudflare%E3%80%82%E8%BF%99%E6%98%AF%E4%B8%8E%E5%8E%9F%E9%95%9C%E5%83%8F%E7%9A%84%E5%94%AF%E4%B8%80%E5%8C%BA%E5%88%AB%E3%80%82
该镜像主要用于结合Caddy反向代理、Let's Encrypt证书服务和Cloudflare DNS进行DNS验证,特别适用于需要为通配符域名获取SSL证书的场景。此外,通过https://github.com/mholt/caddy-dynamicdns%E5%8F%AF%E4%BF%9D%E6%8C%81IP%E5%9C%B0%E5%9D%80%E8%87%AA%E5%8A%A8%E6%9B%B4%E6%96%B0%E3%80%82
如需详细使用方法,建议参考原镜像的https://github.com/lucaslorentz/caddy-docker-proxy%E3%80%82
*.example.com)的SSL证书签发设计通过docker-compose.yml部署,使用标签(labels)定义Caddy配置。以下为基础示例:
yamlversion: "3.3" services: caddy: container_name: caddy image: homeall/caddy-reverse-proxy-cloudflare:latest restart: unless-stopped environment: TZ: 'Europe/London' # 时区设置 volumes: - "/var/run/docker.sock:/var/run/docker.sock" # 需挂载Docker套接字以监听容器事件 - "./caddy-data:/data" # 持久化存储证书等数据 ports: - "80:80" # HTTP端口 - "443:443" # HTTPS端口 labels: # 全局配置 caddy.email: email@example.com # 用于ACME证书注册的邮箱 whoami0: # 示例服务 container_name: whoiam image: jwilder/whoami:latest hostname: YourBigBoss # curl访问时的预期响应 hostname restart: unless-stopped labels: caddy: your.example.com # Caddy监听的域名 caddy.reverse_proxy: "{{upstreams 8000}}" # 反向代理至容器的8000端口 caddy.tls.protocols: "tls1.3" # 可选:TLS协议版本(默认tls1.2) # 测试环境使用Let's Encrypt staging CA(正式环境需删除此行) caddy.tls.ca: "https://acme-staging-v02.api.letsencrypt.org/directory" caddy.tls.dns: "cloudflare $API-TOKEN" # 替换$API-TOKEN为实际Cloudflare API令牌
配置说明
caddy.email:Let's Encrypt证书注册***(必填)caddy:指定Caddy监听的域名(如your.example.com)caddy.reverse_proxy:定义反向代理目标,{{upstreams 8000}}表示自动发现容器的8000端口caddy.tls.dns:Cloudflare DNS验证配置,需替换$API-TOKEN为实际Cloudflare API令牌服务可用性测试
部署后,可通过curl命令测试HTTPS是否正常工作:
bash# 测试证书信息(--insecure用于测试环境,正式环境可移除) curl --insecure -vvI https://your.example.com 2>&1 | awk 'BEGIN { cert=0 } /^\* Server certificate:/ { cert=1 } /^\*/ { if (cert) print }'
预期输出应包含证书信息,如:
* Server certificate: * subject: CN=your.example.com * start date: ... * expire date: ... * issuer: CN=Fake LE Intermediate X1 # 测试环境CA,正式环境为Let's Encrypt
访问服务内容:
bashcurl -k https://your.example.com # -k用于测试环境跳过证书验证
预期返回后端服务响应(如示例中的YourBigBoss主机名)。
健康检查验证
通过Docker命令检查Caddy服务健康状态:
bashdocker inspect --format "{{json .State.Health }}" caddy | jq
健康状态输出示例:
json{ "Status": "healthy", "FailingStreak": 0, "Log": [ { "Start": "...", "End": "...", "ExitCode": 0, "Output": "" } ] }
本项目基于MIT许可证开源,详情参见https://raw.githubusercontent.com/homeall/caddy-reverse-proxy-cloudflare/main/LICENSE%E3%80%82
如有问题,建议在https://github.com/homeall/caddy-reverse-proxy-cloudflare%E6%8F%90%E4%BA%A4issue%E3%80%82
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务