CentOS 7配置Let’s Encrypt支持免費泛域名證書
阿新 • • 發佈:2018-03-24
證書 token rep -h clas oot serve 執行 details
Let’s Encrypt從2018年開始支持泛域名證書,有效期3個月,目前僅支持acme方式申請,暫不支持certbot。
1、安裝acme.sh
curl https://get.acme.sh | sh
2、請求證書(泛域名以*.s-b.me為例)
cd /.acme.sh ./acme.sh --issue -d *.s-b.me -d s-b.me --dns --yes-I-know-dns-manual-mode-enough-go-ahead-please
輸出:
[Sat Mar 24 13:10:07 UTC 2018] Registering account [Sat Mar 24 13:10:08 UTC 2018] Registered [Sat Mar 24 13:10:08 UTC 2018] ACCOUNT_THUMBPRINT=‘hS_gwvXaqMtxJh2Bz0asmWK3r7iMYIknkOWDqO1a76U‘ [Sat Mar 24 13:10:08 UTC 2018] Creating domain key [Sat Mar 24 13:10:09 UTC 2018] The domain key is here: /root/.acme.sh/*.s-b.me/*.s-b.me.key [Sat Mar 24 13:10:09 UTC 2018] Multi domain=‘DNS:*.s-b.me,DNS:s-b.me‘ [Sat Mar 24 13:10:09 UTC 2018] Getting domain auth token for each domain [Sat Mar 24 13:10:10 UTC 2018] Getting webroot for domain=‘*.s-b.me‘ [Sat Mar 24 13:10:10 UTC 2018] Getting webroot for domain=‘s-b.me‘ [Sat Mar 24 13:10:10 UTC 2018] Add the following TXT record: [Sat Mar 24 13:10:10 UTC 2018] Domain: ‘_acme-challenge.s-b.me‘ [Sat Mar 24 13:10:10 UTC 2018] TXT value: ‘6sf1Iuh7r****************bHPs8QriJf8ibpszRk‘ [Sat Mar 24 13:10:10 UTC 2018] Please be aware that you prepend _acme-challenge. before your domain [Sat Mar 24 13:10:10 UTC 2018] so the resulting subdomain will be: _acme-challenge.s-b.me [Sat Mar 24 13:10:10 UTC 2018] Add the following TXT record: [Sat Mar 24 13:10:10 UTC 2018] Domain: ‘_acme-challenge.s-b.me‘ [Sat Mar 24 13:10:10 UTC 2018] TXT value: ‘iA68V9A14****************mlrsZx24raM-S0gmpI‘ [Sat Mar 24 13:10:10 UTC 2018] Please be aware that you prepend _acme-challenge. before your domain [Sat Mar 24 13:10:10 UTC 2018] so the resulting subdomain will be: _acme-challenge.s-b.me [Sat Mar 24 13:10:10 UTC 2018] Please add the TXT records to the domains, and re-run with --renew. [Sat Mar 24 13:10:10 UTC 2018] Please add ‘--debug‘ or ‘--log‘ to check more details. [Sat Mar 24 13:10:10 UTC 2018] See: https://github.com/Neilpang/acme.sh/wiki/How-to-debug-acme.sh
3、參考輸出,添加域名txt記錄,以驗證域名所有權
_acme-challenge.s-b.me txt iA68V9A14****************mlrsZx24raM-S0gmpI _acme-challenge.s-b.me txt 6sf1Iuh7r****************bHPs8QriJf8ibpszRk
4、申請泛解析證書
./acme.sh --renew -d *.s-b.me -d s-b.me --dns --yes-I-know-dns-manual-mode-enough-go-ahead-please
如果順利,會在當前目錄下生成以泛域名為名字的證書目錄
/root/.acme.sh *.s-b.me/ ├── ca.cer ├── fullchain.cer ├── *.s-b.me.cer ├── *.s-b.me.conf ├── *.s-b.me.csr ├── *.s-b.me.csr.conf └── *.s-b.me.key
5、配置nginx或其他web server以支持SSL訪問
.cer 是證書文件 .key 是私鑰文件
fullchain.cer 是證書鏈證書
6、證書續期
通過crontab或者其他定時任務系統執行
./acme.sh --renew -d *.s-b.me -d s-b.me --dns --yes-I-know-dns-manual-mode-enough-go-ahead-please
【參考】
https://github.com/Neilpang/acme.sh
https://keelii.github.io/2016/06/12/free-https-cert-lets-encrypt-apply-install/
CentOS 7配置Let’s Encrypt支持免費泛域名證書