Traefik:使用默认证书时日志中显示“域不需要生成 ACME 证书”

Jea*_*eau 5 ssl swarm certbot traefik acme

我正在为我的 Docker Swarm 的 Let's Encrypt 设置而苦苦挣扎。Traefik 在我的堆栈的 compose 文件中以这种方式启动:

    image: traefik:v2.2
    ports:
      - 80:80
      - 443:443
      - 8080:8080
    command:
      - --api
      - --log.level=DEBUG
      - --providers.docker=true
      - --providers.docker.endpoint=unix:///var/run/docker.sock
      - --providers.docker.swarmMode=true
      - --providers.docker.exposedbydefault=false
      - --providers.docker.network=traefik-public
      - --entrypoints.http.address=:80
      - --entrypoints.https.address=:443

      - --certificatesResolvers.certbot=true
      - --certificatesResolvers.certbot.acme.httpChallenge=true
      - --certificatesResolvers.certbot.acme.httpChallenge.entrypoint=http
      - --certificatesResolvers.certbot.acme.email=${EMAIL?Variable EMAIL not set}
      - --certificatesResolvers.certbot.acme.storage=/certs/acme-v2.json
      - --certificatesResolvers.certbot.acme.caserver=https://acme-staging-v02.api.letsencrypt.org/directory

    ...networks, volumes...

    deploy:
      mode: replicated
      replicas: 1 # to avoid concurrency issues
      ...
      labels:
        - "traefik.docker.network=traefik-public"
        - "traefik.enable=true"
        - "traefik.http.services.traefik.loadbalancer.server.port=8080"
        - "traefik.http.routers.traefik.rule=Host(`traefik.my-domain.com`)"
        - "traefik.http.routers.traefik.entrypoints=http,https"
        - "traefik.http.routers.traefik.tls.certresolver=certbot"
        - "traefik.http.routers.traefik.middlewares=traefik-auth"
        - "traefik.http.middlewares.traefik-auth.basicauth.users=admin:${HASHED_PASSWORD?Variable HASHED_PASSWORD not set}"

Run Code Online (Sandbox Code Playgroud)

我无法得到更多

level=debug msg="No ACME certificate generation required for domains [\"traefik.my-domain.com\"]." providerName=certbot.acme routerName=traefik@docker rule="Host(`traefik.my-domain.com`)"
Run Code Online (Sandbox Code Playgroud)

我想知道为什么不需要 ACME 证书,而 Firefox 抱怨获得“TRAEFIK DEFAULT CERT”(顺便说一句,Chromium 也是如此)。

我也尝试过:

  • 没有让我们加密的临时服务器
  • 面对 DNS 挑战,我希望使其与通配符 *.my-domain.com 一起用于开发目的(与 certbot 手动配合)。
  • 设置 traefik.my-domain.com DNS 区域(以消除问题中的通配符大小写)
  • 按照此处的建议,更改了全局部署的“复制”模式Traefik + Consul 未使用 TRAEFIK DEFAULT CERT 在复制模式下生成 SSL 证书
  • 我目前正在寻找一种直接在我的服务器上使用 Certbot 处理证书更新的方法......

小智 3

我遇到了同样的问题,它帮助我更改了存储 acme.json 的卷。我认为这是因为 Traefik 看到acme.json不为空,他只是不要求新的证书。

所以如果你使用类似的东西:

command:
...
  - --certificatesResolvers.certbot.acme.storage=/certs/acme-v2.json
volumes:
  - "certs:/certs"
Run Code Online (Sandbox Code Playgroud)

尝试使用不同的音量:

command:
...
  - --certificatesResolvers.certbot.acme.storage=/letsencrypt/acme-v2.json
volumes:
  - "letsencrypt:/letsencrypt"
Run Code Online (Sandbox Code Playgroud)