|
本文目录安装acme.sh使用acme.sh签发证书acme.sh提示参考前文 使用Let’s Encrypt获取免费证书 介绍了使用 certbot 工具从Let’s Encrypt获取免费证书。但certbot需要自行设置定时任务更新证书、依赖于新版 Python(Debian 9等系统的Python是即将放弃支持的Python 3.5)、以及不少DNS验证插件需要自行安装。- A9 ^9 O l; a" h" ]
鉴于上述缺点,考虑换成自动化程度更高、使用起来更简易的另一个ACME协议客户端:acme.sh。本教程简要介绍使用acme.sh从Let’s Encrypt获取免费证书。
8 M' `7 a2 S( m7 J* } 安装acme.sh返回目录acme.sh 官网是 https://github.com/acmesh-official/acme.sh,里面已经有比较详细的中文使用说明。: C+ B' E" ]! q$ v4 C% f
首先是安装acme.sh:( b! Q" v9 M! u, ]$ @% m9 d
curl https://get.acme.sh | sh如果提示“curl: command not found”,CentOS/RHEL/Aliyun OS等衍生系统使用:yum install -y curl,Debian/Ubuntu及衍生系统使用:apt install -y curl 安装curl,然后再次运行上面的acme.sh安装命令。+ |( D8 g& h9 z" k' Y) w* ? L. T
更新:新版acme.sh使用ZeroSSL作为CA,建议切换到Let’s Encrypt的CA:acme.sh --set-default-ca --server letsencrypt( `6 W6 P7 `( ~) D% G! P7 V
acme.sh 依赖于cron执行定时任务,安装完成后,输入 crontab -l 命令,能看到如下输出:" C& t* c8 y% M7 |
41 0 * * * "/root/.acme.sh"/acme.sh --cron --home "/root/.acme.sh" > /dev/null定时任务保证了证书在到期前能自动续期。由于ACME协议和Let’s Encrypt CA都在频繁的更新,因此建议开启acme.sh的自动升级:+ m& z6 i, W( g1 ` Q) H/ [
~/.acme.sh/acme.sh --upgrade --auto-upgrade使用acme.sh签发证书返回目录使用acme.sh签发证书非常简单:
% [! l4 d3 |) p& Z8 R8 H, @9 i1. 如果你的服务器上已经运行了web软件,指定webroot即可签发证书:
& b$ m4 s6 l0 E~/.acme.sh/acme.sh --issue -d 域名 --webroot web目录如果要为多个域名签发,直接加 -d 域名 就可以。) i) k8 w( b2 [9 Q) C
需要注意的是,非DNS验证方式签发证书的前提都是域名的IP需要指向当前服务器,并且防火墙需要) Y5 V- q4 @3 D7 T
2. 如果网站已经运行Nginx/Apache,指定对应插件就可以了:
3 D6 J/ E( L2 A% [; j~/.acme.sh/acme.sh --issue -d 域名 --nginx # 如果是apache,换成 --apache3. 如果没有运行web软件并且80端口空闲,可以使用acme.sh自己监听80端口进行验证:
. q+ _. A2 C* p~/.acme.sh/acme.sh --issue -d 域名 --standalone4. 也可以使用DNS方式,手动添加DNS记录进行验证:
5 g6 F; T T0 T2 b1 l1 h) g~/.acme.sh/acme.sh --issue --dns -d 域名
4 P% l2 |2 l1 Z: R S( X6 w/ g( b0 z# 命令结束后,acme.sh会显示解析记录,需要到DNS后台设置解析
% ?. P# y U' x& f# 设置好解析后,生成证书
. J1 _9 {5 ^+ f8 }/ T5 g' `6 u~/.acme.sh/acme.sh --renew -d 域名对于DNS方式,acme.sh内置了许多DNS服务商的插件,使用方法参考:https://github.com/Neilpang/acme.sh/blob/master/dnsapi/README.md
6 \/ C+ J' J# i. g; }2 ~+ H' s/ m如果有通配符证书要求,需要使用DNS验证方式,其他方式一个证书的域名数不能超过20
( r6 t5 q; ~6 J2 `6 ~7 `& [申请好证书的证书位于~/.acme.sh目录内,不建议直接使用,而是将其安装到指定目录:/ G. Q" p: G5 Z5 x/ f0 L* O
~/.acme.sh/acme.sh --install-cert -d 域名 \
& F! i" G: H2 t3 K--key-file 密钥存放目录 \
6 M8 W6 W- v! R m, t--fullchain-file 证书存放路径 \
3 X$ N/ ?, h, w0 X& [" m- ?7 K8 o& b- J--reloadcmd "service nginx force-reload"其中--reloadcmd是可选的,用来安装好证书后重启web服务器。
' ]9 p( h% P. ?0 ?. q0 ]接下来配置好网站的SSL配置(参考 使用Let’s Encrypt获取免费证书 ),就可以愉快的用HTTPS方式访问你的站点了。
% A: H# B3 I$ ^( Q' J+ C acme.sh提示返回目录上面提到的申请和安装命令,执行过一次后,acme.sh便会记下你的操作,在证书即将到期前自动帮你执行一遍,非常的好用和贴心。& y { P# E) @2 U1 P8 R6 Z
参考返回目录[ol]从阿里云获取免费SSL证书pip 21.0 停止支持 Python 2 和 Python 3.5v2ray高级技巧:流量伪装trojan教程Xray教程[/ol]AD:【加速器推荐】 搬瓦工官方代理服务Just My Socks,高速CN2 GIA线路流畅访问外网,被墙自动更换IP打赏赞(6) |
|