使用acme.sh脚本部署HTTPS证书至nginx
目录
使用acme.sh –dns 生成证书
多域名配置
如果使用多个域名(多个云账户)可以指定acmesh 的配置目录
acme.sh --home /root/.acme.sh_68hub_com --config-home /root/.acme.sh_68hub_com --dns dns_ali --issue -d 68hub.com
还需要手动添加对应的crontab命令
0 22 * * * "/root/.acme.sh"/acme.sh --cron --home "/root/.acme.sh_68hub_com" --config-home "/root/.acme.sh_68hub_com" > /dev/null
准备工作(使用阿里云)
-
导入对应的dnsapi环境变量 文档
export Ali_Key="sdfsdfsdfljlbjkljlkjsdfoiwje" export Ali_Secret="jlsdflanljkljlfdsaklkjflsa"
-
生成证书
./acme.sh --issue --dns dns_ali -d 68hub.com
-
安装证书至Nginx
acme.sh --install-cert -d 68hub.com \ --key-file /path/to/keyfile/in/nginx/key.pem \ --fullchain-file /path/to/fullchain/nginx/cert.pem \ --reloadcmd "service nginx force-reload"
-
更新nginx中站点配置,配置nginx中的ssl证书
ssl_certificate /path/to/keyfile/in/nginx/cert.pem; ssl_certificate_key /path/to/fullchain/nginx/key.pem;
配置
对应的项目目录中创建.well-known/acme-challenge
文件
mkdir -p /data/wwwroot/blog.68hub.com/.well-known/acme-challenge
chown -R root:www /data/wwwroot/blog.68hub.com
创建一个location
配置块
# /usr/local/nginx/conf/blog.68hub.com-webroot
location /.well-known/acme-challenge/ {
alias /data/wwwroot/blog.68hub.com/.well-known/acme-challenge/;
}
在对应项目nginx配置文件中加入配置块
# /usr/local/nginx/conf/vhosts/blog.68hub.com.conf
server {
listen 80;
server_name blog.68hub.com;
# ....
# Let's Encrypt webroot
include /usr/local/nginx/conf/blog.68hub.com-webroot;
}
重启nginx。systemctl reload nginx.service
颁发证书
acme.sh --issue -d blog.68hub.com -w /data/wwwroot/blog.68hub.com
安装证书
将证书存储在/usr/local/nginx/conf/ssl
目录中(事先需要创建该目录)
acme.sh --install-cert -d blog.68hub.com \
--cert-file /usr/local/nginx/conf/ssl/blog.68hub.com.crt \
--key-file /usr/local/nginx/conf/ssl/blog.68hub.com.key \
--fullchain-file /usr/local/nginx/conf/ssl/blog.68hub.com.fullchain \
--reloadcmd "service nginx reload"
以上操作将复制证书文件,并创建
cron
命令,默认情况下80天更新一次
更新nginx中站点配置
# /usr/local/nginx/conf/vhosts/blog.68hub.com.conf
server {
...
listen 80;
listen [::]:80;
listen 443 ssl http2;
listen [::]:443 ssl http2;
server_name blog.68hub.com;
ssl_certificate /usr/local/nginx/conf/ssl/blog.68hub.com.crt;
ssl_certificate_key /usr/local/nginx/conf/ssl/blog.68hub.com.key;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2 TLSv1.3;
ssl_ciphers TLS13-AES-256-GCM-SHA384:TLS13-CHACHA20-POLY1305-SHA256:TLS13-AES-128-GCM-SHA256:TLS13-AES-128-CCM-8-SHA256:TLS13-AES-128-CCM-SHA256:EECDH+CHACHA20:EECDH+AES128:RSA+AES128:EECDH+AES256:RSA+AES256:EECDH+3DES:RSA+3DES:!MD5;
ssl_prefer_server_ciphers on;
ssl_session_timeout 10m;
ssl_session_cache builtin:1000 shared:SSL:10m;
ssl_buffer_size 1400;
add_header Strict-Transport-Security max-age=15768000;
# http 重定向至 https
if ($ssl_protocol = "") { return 301 https://$host$request_uri; }
...
}
重启nginx service nginx reload
阅读其他文章