Nginx自动申请证书

为了安全性,我们一般需要使用https来搭建网站,这里就难免涉及到ssl证书的申请,一般手动操作的模式比较繁琐,所以这里介绍一下利用acme来自动申请及更新证书。

1. 安装 acme.sh

安装很简单, 一个命令:

1
curl https://get.acme.sh | sh -s [email protected]

普通用户和 root 用户都可以安装使用. 安装过程进行了以下几步:

  1. 把 acme.sh 安装到你的 home 目录下:
    /.acme.sh/
    并创建 一个 shell 的 alias, 例如 .bashrc,方便你的使用: ```alias acme.sh=
    /.acme.sh/acme.sh```

  2. 自动为你创建 cronjob, 每天 0:00 点自动检测所有的证书, 如果快过期了, 需要更新, 则会自动更新证书.

更高级的安装选项请参考: https://github.com/Neilpang/acme.sh/wiki/How-to-install
安装过程不会污染已有的系统任何功能和文件, 所有的修改都限制在安装目录中: ~/.acme.sh/

2. 生成证书

这里直接使用DNS的方式来验证,这里以阿里DNS为例,其他DNS用法可以参考官方文档

1
2
3
4
5
# 这里首先需要获取阿里API的key
export Ali_Key="sdfsdfsdfljlbjkljlkjsdfoiwje"
export Ali_Secret="jlsdflanljkljlfdsaklkjflsa"

./acme.sh --issue --dns dns_ali -d example.com -d *.example.com

证书就会自动生成了. 这里给出的 Ali_KeyAli_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
2
3
4
acme.sh --install-cert -d example.com \
--key-file /path/to/keyfile/in/nginx/key.pem \
--fullchain-file /path/to/fullchain/nginx/cert.pem \
--reloadcmd "service nginx force-reload"

这里Nginx的证书使用fullchain,不然可能会出错

–install-cert命令可以携带很多参数, 来指定目标文件. 并且可以指定 reloadcmd, 当证书更新以后, reloadcmd会被自动调用,让服务器生效.

详细参数请参考: https://github.com/Neilpang/acme.sh#3-install-the-issued-cert-to-apachenginx-etc

值得注意的是, 这里指定的所有参数都会被自动记录下来, 并在将来证书自动更新以后, 被再次自动调用.

4. 更新证书

证书在 60 天以后会自动更新, 你无需任何操作. 今后有可能会缩短这个时间, 不过都是自动的, 你不用关心.
请确保 cronjob 正确安装, 看起来是类似这样的:

1
2
3
crontab  -l

56 * * * * "/root/.acme.sh"/acme.sh --cron --home "/root/.acme.sh" > /dev/null

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