扫一扫,微信登陆

 青浦修电脑 青浦笔记本维修 青浦手机维修 青浦电器维修

搜索
查看: 308|回复: 0

使用acme.sh签发证书 - 青浦海洋数码电脑城

[复制链接]

1万

主题

1万

帖子

5万

积分

论坛元老

Rank: 8Rank: 8

积分
56206
发表于 2022-9-11 21:04:51 | 显示全部楼层 |阅读模式
本文目录
  • 安装acme.sh
  • 使用acme.sh签发证书
  • acme.sh提示
  • 参考前文 使用Let’s Encrypt获取免费证书 介绍了使用 certbot 工具从Let’s Encrypt获取免费证书。但certbot需要自行设置定时任务更新证书、依赖于新版 Python(Debian 9等系统的Python是即将放弃支持的Python 3.5)、以及不少DNS验证插件需要自行安装。
    , V4 j7 }4 ]) U; P& |5 d鉴于上述缺点,考虑换成自动化程度更高、使用起来更简易的另一个ACME协议客户端:acme.sh。本教程简要介绍使用acme.sh从Let’s Encrypt获取免费证书。/ o) k4 M+ {9 @) a' T
    安装acme.sh返回目录acme.sh 官网是 https://github.com/acmesh-official/acme.sh,里面已经有比较详细的中文使用说明。
    7 `, s1 b: v( |. j4 o- \' x, v首先是安装acme.sh:
    . @+ w  n" m  K3 O$ u" U  _5 tcurl 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安装命令。5 y( Z7 q0 S5 k: V1 e6 N
    更新:新版acme.sh使用ZeroSSL作为CA,建议切换到Let’s Encrypt的CA:acme.sh --set-default-ca --server letsencrypt
    9 ]! w1 N' m; y1 M
    acme.sh 依赖于cron执行定时任务,安装完成后,输入 crontab -l 命令,能看到如下输出:% [; d1 b5 p; _9 A8 ?$ S1 d. Z' k" j: J
    41 0 * * * "/root/.acme.sh"/acme.sh --cron --home "/root/.acme.sh" > /dev/null定时任务保证了证书在到期前能自动续期。由于ACME协议和Let’s Encrypt CA都在频繁的更新,因此建议开启acme.sh的自动升级:( B- }2 t5 C/ M+ Y5 Z
    ~/.acme.sh/acme.sh  --upgrade  --auto-upgrade使用acme.sh签发证书返回目录使用acme.sh签发证书非常简单:
    ) b3 Z, q: y4 }  D% o% B6 n1. 如果你的服务器上已经运行了web软件,指定webroot即可签发证书:
    " S+ w9 U/ T8 Z( F: \4 @% N~/.acme.sh/acme.sh --issue -d 域名 --webroot web目录如果要为多个域名签发,直接加 -d 域名 就可以。
    1 H/ y, i& Z( M1 h: t$ I7 ?! Y需要注意的是,非DNS验证方式签发证书的前提都是域名的IP需要指向当前服务器,并且防火墙需要: [, m, N2 ?/ V( J( D
    2. 如果网站已经运行Nginx/Apache,指定对应插件就可以了:
    + \* Q! V+ U, ^: X) D~/.acme.sh/acme.sh --issue -d 域名 --nginx # 如果是apache,换成 --apache3. 如果没有运行web软件并且80端口空闲,可以使用acme.sh自己监听80端口进行验证:( Q. h0 b4 i6 s. O: d  L+ R! j* L: y
    ~/.acme.sh/acme.sh --issue -d 域名 --standalone4. 也可以使用DNS方式,手动添加DNS记录进行验证:
    * W- t+ g$ q, B% ^, o~/.acme.sh/acme.sh --issue --dns -d 域名) S9 K5 S- [* D1 r: A, V
    # 命令结束后,acme.sh会显示解析记录,需要到DNS后台设置解析
    6 y, h) ]1 t. D. A8 b; x1 K$ R0 B# 设置好解析后,生成证书
    0 U" ^7 k: i$ ?9 ]~/.acme.sh/acme.sh --renew -d 域名对于DNS方式,acme.sh内置了许多DNS服务商的插件,使用方法参考:https://github.com/Neilpang/acme.sh/blob/master/dnsapi/README.md
    $ q6 o& N* |4 f- U如果有通配符证书要求,需要使用DNS验证方式,其他方式一个证书的域名数不能超过20! G! y5 W: S  J
    申请好证书的证书位于~/.acme.sh目录内,不建议直接使用,而是将其安装到指定目录:
    , N9 m# T5 l  c8 T3 W- d0 k7 P~/.acme.sh/acme.sh --install-cert -d 域名 \& Y$ _0 C8 S3 i* t' ]$ D% F" O
    --key-file       密钥存放目录  \
    $ h5 X. ?3 x: W& C' V4 I* Q8 W3 z--fullchain-file 证书存放路径 \. J, Q' j& ^3 c) L# b
    --reloadcmd     "service nginx force-reload"其中--reloadcmd是可选的,用来安装好证书后重启web服务器。4 p+ h9 ]7 i* h4 ^' a& T5 {
    接下来配置好网站的SSL配置(参考 使用Let’s Encrypt获取免费证书 ),就可以愉快的用HTTPS方式访问你的站点了。
    7 K% x. N+ a# ~! c4 O) J% j acme.sh提示返回目录上面提到的申请和安装命令,执行过一次后,acme.sh便会记下你的操作,在证书即将到期前自动帮你执行一遍,非常的好用和贴心。; k) k. W7 l: v# a8 r( ~0 d1 G
    参考返回目录[ol]
  • 从阿里云获取免费SSL证书
  • pip 21.0 停止支持 Python 2 和 Python 3.5
  • v2ray高级技巧:流量伪装
  • trojan教程
  • Xray教程[/ol]AD:【加速器推荐】 搬瓦工官方代理服务Just My Socks,高速CN2 GIA线路流畅访问外网,被墙自动更换IP打赏赞(6)
  • 回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    Copyright © 2001-2013 Comsenz Inc.Powered by Discuz!X3.4( 沪ICP备18024137号 )
    快速回复 返回顶部 返回列表