
hk.v2fy.com
下面开始添加https
安装 acme.sh
curl https://get.acme.sh | sh -s email=zhaoolee@gmail.com
source ~/.bashrc
获取https证书
acme.sh --issue -d hk.v2fy.com --nginx
https证书生成的位置
在这一步acme.sh读取了nginx配置,并自动生成了证书
将证书拷贝到/etc/nginx/ssl文件夹
创建文件夹
mkdir -p /etc/nginx/ssl/hk.v2fy.com
拷贝证书
acme.sh --install-cert -d hk.v2fy.com \
--key-file /etc/nginx/ssl/hk.v2fy.com/hk.v2fy.com.key \
--fullchain-file /etc/nginx/ssl/hk.v2fy.com/fullchain.cer \
--reloadcmd "service nginx force-reload"
请一定使用以上语法acme.sh --install-cer进行拷贝, 这样证书才能保证在新的位置也能自动更新。
证书拷贝成功
将 /etc/nginx/ssl/hk.v2fy.com/ 中的证书手动配置到 nginx, 并重启nginx生效
将/etc/nginx/conf.d/hk.v2fy.com.conf中的内容替换为
server {
listen 80;
listen [::]:80;
server_name hk.v2fy.com;
root /usr/share/nginx/html/hk.v2fy.com;
error_page 404 /404.html;
location = /404.html {
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
}
}
server {
listen 443 ssl http2;
listen [::]:443 ssl http2;
server_name hk.v2fy.com;
root /usr/share/nginx/html/hk.v2fy.com;
ssl_certificate "/etc/nginx/ssl/hk.v2fy.com/fullchain.cer";
ssl_certificate_key "/etc/nginx/ssl/hk.v2fy.com/hk.v2fy.com.key";
ssl_session_cache shared:SSL:1m;
ssl_session_timeout 10m;
ssl_ciphers HIGH:!aNULL:!MD5;
ssl_prefer_server_ciphers on;
# Load configuration files for the default server block.
include /etc/nginx/default.d/*.conf;
error_page 404 /404.html;
location = /40x.html {
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
}
}
打开 https://hk.v2fy.com
证书已生效
证书获得
由于我们全程使用 acme.sh 进行安装,acme.sh会自动为你创建一个定时任务, 每天 0:00 点自动检测所有的证书, 如果快过期了, 需要更新, 则会自动更新证书.
自动创建f
运行ps aux | grep acme可以看到scme一直在后台运行
ps aux | grep acme
如何实现多个证书同步更新
如果你需要多个证书,比如给 api.v2fy.com 配置证书, 重复本文步骤即可~
acme.sh --issue -d api.v2fy.com --nginx
新证书
创建文件夹
mkdir -p /etc/nginx/ssl/api.v2fy.com
拷贝证书
acme.sh --install-cert -d api.v2fy.com \
--key-file /etc/nginx/ssl/api.v2fy.com/api.v2fy.com.key \
--fullchain-file /etc/nginx/ssl/api.v2fy.com/fullchain.cer \
--reloadcmd "service nginx force-reload"
设置 /etc/nginx/conf.d/api.v2fy.com.conf
server {
listen 80;
listen [::]:80;
server_name api.v2fy.com;
root /usr/share/nginx/html/api.v2fy.com;
error_page 404 /404.html;
location = /404.html {
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
}
}
server {
listen 443 ssl http2;
listen [::]:443 ssl http2;
server_name api.v2fy.com;
root /usr/share/nginx/html/api.v2fy.com;
ssl_certificate "/etc/nginx/ssl/api.v2fy.com/fullchain.cer";
ssl_certificate_key "/etc/nginx/ssl/api.v2fy.com/api.v2fy.com.key";
ssl_session_cache shared:SSL:1m;
ssl_session_timeout 10m;
ssl_ciphers HIGH:!aNULL:!MD5;
ssl_prefer_server_ciphers on;
# Load configuration files for the default server block.
include /etc/nginx/default.d/*.conf;
error_page 404 /404.html;
location = /40x.html {
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
}
}
打开 https://api.v2fy.com 查看效果
https配置成功
小结
免费的https证书,最多只有一年的期限, 而且每个二级子域名要单独申请, 很浪费时间,使用本文提供的方法,可以只配置一次,实现证书永久自动续期。

评论列表