前文 使用Let’s Encrypt获取免费证书 介绍了使用 certbot 工具从Let’s Encrypt获取免费证书。但certbot需要自行设置定时任务更新证书、依赖于新版 Python(Debian 9等系统的Python是即将放弃支持的Python 3.5)、以及不少DNS验证插件需要自行安装。
鉴于上述缺点,考虑换成自动化程度更高、使用起来更简易的另一个ACME协议客户端:acme.sh
。本教程简要介绍使用acme.sh
从Let’s Encrypt获取免费证书。
使用acme.sh签发证书
安装acme.sh
acme.sh
官网是 https://github.com/acmesh-official/acme.sh,里面已经有比较详细的中文使用说明。
首先是安装acme.sh
:
curl https://get.acme.sh | sh
如果提示“curl: command not found”,CentOS/RHEL/Aliyun OS等衍生系统使用:yum install -y curl
,Debian/Ubuntu及衍生系统使用:apt install -y curl
安装curl
,然后再次运行上面的acme.sh安装命令。
acme.sh
依赖于cron
执行定时任务,安装完成后,输入 crontab -l
命令,能看到如下输出:
41 0 * * * "/root/.acme.sh"/acme.sh --cron --home "/root/.acme.sh" > /dev/null
定时任务保证了证书在到期前能自动续期。由于ACME协议和Let’s Encrypt CA都在频繁的更新,因此建议开启acme.sh的自动升级:
~/.acme.sh/acme.sh --upgrade --auto-upgrade
签发证书
使用acme.sh
签发证书非常简单:
1. 如果你的服务器上已经运行了web软件,指定webroot即可签发证书:
~/.acme.sh/acme.sh --issue -d 域名 --webroot web目录
如果要为多个域名签发,直接加 -d 域名
就可以。
需要注意的是,非DNS验证方式签发证书的前提都是域名的IP需要指向当前服务器,并且防火墙需要
2. 如果网站已经运行Nginx/Apache,指定对应插件就可以了:
~/.acme.sh/acme.sh --issue -d 域名 --nginx # 如果是apache,换成 --apache
3. 如果没有运行web软件并且80端口空闲,可以使用acme.sh自己监听80端口进行验证:
~/.acme.sh/acme.sh --issue -d 域名 --standalone
4. 也可以使用DNS方式,手动添加DNS记录进行验证:
~/.acme.sh/acme.sh --issue --dns -d 域名 # 命令结束后,acme.sh会显示解析记录,需要到DNS后台设置解析 # 设置好解析后,生成证书 ~/.acme.sh/acme.sh --renew -d 域名
对于DNS方式,acme.sh内置了许多DNS服务商的插件,使用方法参考:https://github.com/Neilpang/acme.sh/blob/master/dnsapi/README.md
如果有通配符证书要求,需要使用DNS验证方式,其他方式一个证书的域名数不能超过20
申请好证书的证书位于~/.acme.sh
目录内,不建议直接使用,而是将其安装到指定目录:
~/.acme.sh/acme.sh --install-cert -d 域名 \
--key-file 密钥存放目录 \
--fullchain-file 证书存放路径 \
--reloadcmd "service nginx force-reload"
其中--reloadcmd
是可选的,用来安装好证书后重启web服务器。
接下来配置好网站的SSL配置(参考 使用Let’s Encrypt获取免费证书 ),就可以愉快的用HTTPS方式访问你的站点了。
其他
上面提到的申请和安装命令,执行过一次后,acme.sh
便会记下你的操作,在证书即将到期前自动帮你执行一遍,非常的好用和贴心。
文章里的”~”符号用的都是全角,奇怪。
这么奇怪,有空我改改
我一直搞不懂通配符的意思,请教一下!安装XRAY和NGINX的时候,我使用了下面这些命令在一台VPS安装了通配符证书curl https://get.acme.sh | sh
source ~/.bashrc
导入CF的API:
export CF_Key=”xxxxxxxxxxxxx”
export CF_Email=”xxxxxxxxxxxxx”
~/.acme.sh/acme.sh –issue –dns dns_cf -d abcd.me -d *.abcd.me -k ec-256
~/.acme.sh/acme.sh –install-cert -d abcd.me -d *.abcd.me –fullchainpath /etc/v2ray/abcd.me.crt –keypath /etc/v2ray/abcd.me.key –ecc
定期自动更新
acme.sh –upgrade –auto-upgrade
证书安装成功后,假如我有另外一台VPS的IP也解析在这个abcd.me域名下,申请的是这个abcd.me的二级chery.abcd.me,那我在这台VPS下该怎么安装和使用我前面那个已经申请通配符的证书用在这台新的vps上面呢?需要从新走一遍上面的脚本命令来安装申请这个chery.abcd.me的证书吗?
可以把证书复制过去,也可以重新运行申请一次
感谢回复!那请问如果重新申请的话,CF-key需要重新导入吗?这条代码~/.acme.sh/acme.sh –issue –dns dns_cf -d abcd.me -d *.abcd.me -k ec-256还是这样去申请这个根域名吗?还是要变成这样我的二级域名~/.acme.sh/acme.sh –issue –dns dns_cf -d chery.abcd.me -d *.chery.abcd.me -k ec-256去申请?
同一台服务器上只需要运行~/.acme.sh/acme.sh –install-cert安装证书就好了,不同的服务器上需要设置CF-key这些变量,然后再次申请和安装
感谢热心回复!