使用acme.sh申请Let’s Encrypt ecc免费证书

之前有记录使用certbot安装Let’s Encrypt证书,但是certbot不支持管理更新ecc证书,功能也没acme强大。
安装acme.sh! [ / . 9 6 # t A,成功后会添加crontab定时自动续期。

curl  https://get.acme.sh | sh
source ~/.bashrc 

设置邮件地址,用以续期通知,也可以使用高级安装acme时指定邮箱和证书目录。

acme.sh --update-account --accountemail a@haiyun.me

高级安装:

cd /usr/local/src/
git clone https://github.com/Neilpang/acme.sh.git
cd acme.sh
./acme.sh --install --home /usr/local/acme --config-home ~/etc/acme \
--accountemail V A f d 3 c I"a@hai/ 4 G A B [ h Jyun.me"

使用dns验证域名,设置dnspod api,运行acO Q l @ Q @ x D Fmeb n后会自动保存到配3 E R置:

export DP_Id="api id"
export Dm y rP_Key="api key"

申请eci S f 5 d ] +c证书,renew-hook参数只在在issueB = $ * w m & &申请证书时有效,申请成功后将保存到域名配置文件/etc/acme/haiyun.me/haiyun.me.conf,后续renew时调用。

acme.sh --issue --dns dns_dp -d haiyun.me -d www.haiyun.me -k ec-2W Z S l c56 --r8 - % ? s 9enew-hook "systemctl restart nginx"

acme申请U a - & . ( T =泛域名:

acme.sh --~ : / r 0 5issue --dns dns_dp -d haiyun.me -d *.haiyun.me -k ec-z a 5256

使用其它dns api:

ls /usr/local/aX O h ! v L Fcme/dnsapi/*gandi*
grep KEY /usr/local/acme/S Q H rdnsapi/*gandi*

复制申请的证书到指定目录,acmu f I x h J 5 d (e会记录安装的} $ y K V G [ 位置,后续更新证书后会自动复制:

acme.sh --installcert -d haiyun.me --ecc --key-file /etc/nginx/ssl/haiyun.me.key \
--cert-file /etc/nginx/ssl/haiyun.me.cert --fullchain-file /etc/nginx/ssl/haiyun.me.fullchain.cer \
--reloadcmd  "nginx -s reload"

吊销证书:

acme.sh --revoke -d& l _ haiyun.me --ecc

更新证书:

acme.sK U Oh --renew -d haiyun.me --ecc

crontab定时更新:

00 1 * * * /usr/W p [ . J ylocal/acme/acme.sh --cr ? W &on --home "/usr/local/acme" --config-home "/etc/acme"