
Let's Encrypt: https://letsencrypt.org , 是一个免费的、自动化的、开放的证书颁发机构。截至2018年9月,它的全球SSL证书市场份额已超过50%,得到主流浏览器和厂商的认可与支持。
Let's Encrypt证书提供免费的申请,但没有高额的安全保险,不具备点对点的技术支持,而且申请过程比较复杂,适合具有一定的专业知识的个人站长申请。并且每次申请到的SSL证书有效期只有90天,但是可以通过脚本实现提前自动续约达到自动化永久免费使用的目的。
在2018年5月,Let's Encrypt发布了免费泛域名通配符SSL证书:https://community.letsencrypt.org/t/acme-v2-and-wildcard-certificate-support-is-live/55579 ,在HTTPS全面普及的当下,越来越多的开发者选择了Let's Encrypt证书。
想要实现免费泛域名SSL证书申请及其自动续签,需要以下材料:
*.qq.com 为例进行泛域名证书申请演示Let's Encrypt官方提供了一系列的申请方法文档,但流程比较复杂,为了简化申请流程,我们可以在Github上找到这个仓库:https://github.com/Neilpang/acme.sh
acme.sh的具体使用说明见:https://github.com/Neilpang/acme.sh/wiki/说明
接下来,我们就利用 acme.sh 对证书进行申请。
acme.sh进入服务器,执行命令:
$ curl https://get.acme.sh | sh普通用户和root用户都可以安装使用,安装脚本其实是进行了如下操作:1)会把
acme.sh安装到你所执行命令用户的用户目录下:~/.acme.sh/2)会创建bash的alias,方便你的使用:alias > acme.sh=~/.acme.sh/acme.sh3)会自动为你创建cronjob脚本,每天零点自动检测所有的证书,如果某证书快过期需要更新,则会自动更新该证书。
安装过程不会污染已有的系统任何功能和文件,所有后续的修改都将限制在安装目录中:~/.acme.sh/
acme.sh 实现了 acme 协议支持的所有验证协议,通常一般有几种方式验证域名:HTTP文件验证 和 DNS验证 等,具体验证方式可查阅脚本github文档。
方式1、HTTP文件验证:
$ acme.sh --issue -d qq.com -d *.qq.com -w /home/webroot
注意:对于通配符证书需要加-d 域名 -d *.域名两个参数-w即webroot,为该域名通过http所访问到的本地目录上面这段过程将会在/home/webroot创建一个.well-known的文件夹,同时 Let’s Encrypt 将会通过你要注册的域名去访问那个文件来确定权限,它可能会去访问 http://qq.com/.well-known/ 这个路径,验证成功会自动清理。
方式2、DNS-API验证:
通过DNS服务器提供 key 与 secret 实现自动验证,详情
https://github.com/Neilpang/acme.sh/tree/master/dnsapi
例如,在腾讯云解析的域名,请前往 https://www.dnspod.cn/console/user/security 控制台中申请子账号 API Token 并执行命令:
$ export DP_Id="6*ID*0"
$ export DP_Key="aa445e***TOKEN***5fe26e"$ acme.sh --issue -d qq.com -d *.qq.com --dns dns_dp
注意:对于通配符证书需要加-d 域名 -d *.域名两个参数DP_Id和DP_Key将会保存在~/.acme.sh/account.conf
执行上述命令后,证书文件将会自动申请被存放在 ~/.acme.sh/ 对应的域名文件夹中,如:~/.acme.sh/qq.com 。后续 acme.sh 将会自动更新该文件夹内的证书。
参考:https://github.com/Neilpang/acme.sh/wiki/说明
1) 拷贝证书
$ acme.sh --install-cert -d qq.com \
--key-file /etc/nginx/ssl/qq.com.key \
--fullchain-file /etc/nginx/ssl/qq.com.cer \
--reloadcmd 'service nginx force-reload'
注意:通过该命令可将~/.acme.sh/qq.com内的证书copy到指定位置/etc/nginx为nginx服务器实际的地址(可修改为自己服务器对应的地址)service nginx force-reload为nginx重启命令(可修改为自己服务器对应的命令),force-reload会重载证书后续acme.sh签发了新证书后就自动完成该拷贝过程
2) 配置nginx
Nginx-Conf
vim /etc/nginx/conf.d/qq.com.conf:
# http(80) -> https(443/ssl)
server {
listen 80;
server_name qq.com;
rewrite ^(.*)$ https://$host$request_uri;
}
# qq.com
server {
listen 443;
server_name qq.com;
include ssl/qq.com.ssl.conf;
location / {
# todo
}
}SSL-Conf
vim /etc/nginx/ssl/qq.com.ssl.conf:
ssl on;
ssl_certificate ssl/qq.com.cer;
ssl_certificate_key ssl/qq.com.key;原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。