本文只适用于在鹅云上备案、解析的域名,已经把成功把HTTPS应用于鹅云的CDN,其他云厂商没有进行试验,有兴趣的伙伴可以自行按照下文的思路重演。
安装ACME
目前使用量最大的免费SSL
证书就是Let’s Encrypt
,自2018-03
开始,Let’s Encrypt
官方发布上线了免费的SSL
泛域名证书,目前通过DNS
方式获取比较快,国内可以通过鹅云的DNSPod
域名API
或者猫云域名API
自动签发Let’s Encrypt
泛域名证书。因为鹅云使用的就是DNSPod
域名,并且鹅云和DNSPod的账号是打通的,可以使用wx
直接扫码登录。下文需要对鹅云和DNSPod
进行操作,为了简化证书申请过程,需要提前安装acme.sh。acme.sh
实现了acme
协议,可以从Let’s Encrypt
生成免费的证书,自动创建cron
任务, 每天零点自动检测所有的证书,如果发现证书快过期了,需要更新,则acme.sh
会自动更新证书,安装过程不会污染已有的系统任何功能和文件,所有的修改都限制在安装目录中。
先进行依赖下载和更新。如果服务器是CentOS
系统,使用下面的命令:
yum update && yum install curl -y && yum install cron -y && yum install socat -y
如果服务器是Debian/Ubuntu
系统,则使用下面的命令:
apt-get update && apt-get install curl -y && apt-get install cron -y && apt-get install socat -y
接着使用下面的命令安装acme.sh
:
curl https://get.acme.sh | sh
如果控制台输出:
.....
Good, bash is found, so change the shebang to use....
OK
Install success!
说明acme.sh
安装成功。
注册并配置DNSPod的秘钥
如果使用了鹅云的服务,直接wx
扫码就可以登录DNSPod
,否则需要注册绑定。登录之后,点击账号中心的「密钥管理」:
然后命名并且创建一个密钥:
记得要保存好秘钥的ID
和Token
,后面的步骤需要用到这两个配置。
申请证书
申请好DNSPod
的秘钥,得到ID
和Token
之后,在服务器的环境变量中添加这几个值,执行命令:
export DP_Id='你的ID'
export DP_Key='你的Token'
export ACCOUNT_EMAIL='你的邮箱'
接着使用acme.sh
申请签发证书,执行命令:
~/.acme.sh/acme.sh --issue --dns dns_dp -d throwable.club -d *.throwable.club
这里throwable.club
是笔者的博客域名,如果需要颁发你自己的域名的SSL
证书,这里替换为你的域名即可。接着静静等待acme.sh
的脚本程序执行完毕,如果过程中没有发生其他意外,那么证书申请成功后的控制台日志如下:
证书文件会自动存放在/root/.acme.sh/域名
目录下,例如/root/.acme.sh/throwable.club
目录。查看/root/.acme.sh/throwable.club
目录的内容:
其中,「fullchain.cer就是证书文件内容,而throwable.club.key就是证书的私钥」
。
最后注意一下:
申请下来的泛域名SSL免费证书有效期只有3个月,但是acme.sh每晚零点会自动检测证书的有效期并且进行续期。
手动续期命令:acme.sh --cron --force --debug 2
怎吗搞没看明白
怎吗搞没看明白
赞赞赞辛苦大佬!
111111
不明觉厉
.......
ssss