Nginx自动申请证书
为了安全性,我们一般需要使用https来搭建网站,这里就难免涉及到ssl证书的申请,一般手动操作的模式比较繁琐,所以这里介绍一下利用acme来自动申请及更新证书。
1. 安装 acme.sh
安装很简单, 一个命令:
1 | curl https://get.acme.sh | sh -s [email protected] |
普通用户和 root 用户都可以安装使用. 安装过程进行了以下几步:
把 acme.sh 安装到你的 home 目录下:
/.acme.sh//.acme.sh/acme.sh```
并创建 一个 shell 的 alias, 例如 .bashrc,方便你的使用: ```alias acme.sh=自动为你创建 cronjob, 每天 0:00 点自动检测所有的证书, 如果快过期了, 需要更新, 则会自动更新证书.
更高级的安装选项请参考: https://github.com/Neilpang/acme.sh/wiki/How-to-install
安装过程不会污染已有的系统任何功能和文件, 所有的修改都限制在安装目录中: ~/.acme.sh/
2. 生成证书
这里直接使用DNS的方式来验证,这里以阿里DNS为例,其他DNS用法可以参考官方文档
1 | # 这里首先需要获取阿里API的key |
证书就会自动生成了. 这里给出的 Ali_Key 和 Ali_Secret 会被自动记录下来, 将来你在使用 alidns api 的时候, 就不需要再次指定了. 直接生成就好了:
1 | ./acme.sh --issue --dns dns_ali -d example.com -d *.example.com |
更详细的 api 用法: https://github.com/Neilpang/acme.sh/blob/master/dnsapi/README.md
3. 安装证书
注意, 默认生成的证书都放在安装目录下: ~/.acme.sh/, 请不要直接使用此目录下的文件, 例如: 不要直接让 nginx/apache 的配置文件使用这下面的文件. 这里面的文件都是内部使用, 而且目录结构可能会变化.
正确的使用方法是使用 –install-cert 命令,并指定目标位置, 然后证书文件会被copy到相应的位置, 例如:
Nginx example:
1 | acme.sh --install-cert -d example.com \ |
这里Nginx的证书使用fullchain,不然可能会出错
–install-cert命令可以携带很多参数, 来指定目标文件. 并且可以指定 reloadcmd, 当证书更新以后, reloadcmd会被自动调用,让服务器生效.
详细参数请参考: https://github.com/Neilpang/acme.sh#3-install-the-issued-cert-to-apachenginx-etc
值得注意的是, 这里指定的所有参数都会被自动记录下来, 并在将来证书自动更新以后, 被再次自动调用.
4. 更新证书
证书在 60 天以后会自动更新, 你无需任何操作. 今后有可能会缩短这个时间, 不过都是自动的, 你不用关心.
请确保 cronjob 正确安装, 看起来是类似这样的:
1 | crontab -l |
5. 更新 acme.sh
目前由于 acme 协议和 letsencrypt CA 都在频繁的更新, 因此 acme.sh 也经常更新以保持同步.
升级 acme.sh 到最新版 :acme.sh --upgrade
如果你不想手动升级, 可以开启自动升级:acme.sh --upgrade --auto-upgrade
之后, acme.sh 就会自动保持更新了.
你也可以随时关闭自动更新:acme.sh --upgrade --auto-upgrade 0
6. 出错怎么办:
如果出错, 请添加 debug log:acme.sh --issue ..... --debug
或者:acme.sh --issue ..... --debug 2
请参考: https://github.com/Neilpang/acme.sh/wiki/How-to-debug-acme.sh