跳到主要内容

acme-dns

  • joohoi/acme-dns 是什么?
    • 专门用于辅助申请 cert 的 dns 服务 - 提供 HTTP 接口
    • 将现有 _acme-challenge.domain.tld. CNAME 到从该服务申请的二级域名 - 例如 abc.auth.example.org
    • 避免操作现有 DNS 服务
    • 支持 selfhost - acme-dns.io 国内不一定能访问
      • 支持 SQLite3 和 PostgreSQL
    • 适用于单个域名需要证书,域名使用的外部 DNS 服务且指向的内部 IP
    • 适用于泛域名证书 - domain.tld, *.domain.tld
  • 支持客户端
一个账号对应一个域名
  • 因为一个账号只能处理两个 record - domain.tld,*.domain.tld
  • 不能 共享账号给不同域名
  • #110 Allow more than two records?
  • #233 Register multiple domains under single login?
注册生成账号
curl -sX POST https://auth.acme-dns.io/register | jq
{
"username": "6f449871-18d4-4239-851c-8c221d56750f",
"password": "1lBTiQ5MowHC1aJ1QmAYJh9PEe5dljFTEk0zXXJv",
"fulldomain": "96afb9f9-93c2-4d3c-ad4a-e2ebfbf14f7b.auth.acme-dns.io",
"subdomain": "96afb9f9-93c2-4d3c-ad4a-e2ebfbf14f7b",
"allowfrom": []
}
添加域名映射
_acme-challenge.domain.tld 6f449871-18d4-4239-851c-8c221d56750f.auth.acme-dns.io

至此 可以配置工具 获取泛域名证书。

dig CNAME _acme-challenge.domain.tld # 检测 CNAME 正确
dig TXT _acme-challenge.domain.tld # 检测正确设置 challenge

cert-manager

apiVersion: cert-manager.io/v1
kind: Issuer
metadata:
name: example-issuer
spec:
acme:
solvers:
- dns01:
acmeDNS:
host: https://acme.example.com
accountSecretRef:
name: acme-dns
key: acme-dns.json

acme-dns.json 支持配置多个域名

acme-dns.json
{
"dev.wener.me": {
"username": "00000000-0000-0000-0000-000000000000",
"password": "",
"fulldomain": "00000000-0000-0000-0000-000000000000.auth.acme-dns.io",
"subdomain": "00000000-0000-0000-0000-000000000000",
"allowfrom": []
},
"test.wener.me": {
"username": "00000000-0000-0000-0000-000000000000",
"password": "",
"fulldomain": "00000000-0000-0000-0000-000000000000.auth.acme-dns.io",
"subdomain": "00000000-0000-0000-0000-000000000000",
"allowfrom": []
}
}