Certbot实现自动签发证书及续签

操作系统Centos9 , Web服务器nginx

一、安装 Certbot 和 Nginx 插件

复制代码
# CentOS 9 启用 EPEL
dnf install -y epel-release

# 安装 certbot 和 nginx 插件
dnf install -y certbot python3-certbot-nginx

二、申请证书

cs 复制代码
certbot certonly --nginx \
  -d fszy.cn \
  -d yxln.cn \
  --email your-email@example.com \
  --agree-tos \
  --no-eff-email
  • 会得到一张证书,包含这 2个域名(多个域名可共用一个证书),路径类似:

/etc/letsencrypt/live/fszy.cn/fullchain.pem

/etc/letsencrypt/live/fszy.cn/privkey.pem

三、Nginx 配置示例

在每个 server 块里使用同一对证书,修改完后重启服务: nginx -t && systemctl reload nginx

复制代码
server {
    listen 443 ssl;
    server_name fszy.cn;  # 或其它域名

    ssl_certificate     /etc/letsencrypt/live/fszy.cn/fullchain.pem;
    ssl_certificate_key /etc/letsencrypt/live/fszy.cn/privkey.pem;

    # 其它配置...
}

四、自动续期

  1. 测试续期命令(不真正续期)
cs 复制代码
certbot renew --dry-run
  1. 续期、续期后自动重载 Nginx服务
cpp 复制代码
#先确认服务路径
which certbot
which systemctl

#配置定时任务
crontab -e
0 3 * * * /usr/bin/certbot renew --quiet --deploy-hook "/usr/bin/systemctl reload nginx"

--quiet:这个选项让certbot以静默方式运行,不输出无关信息,只输出错误信息。

--deploy-hook "/usr/bin/systemctl reload nginx":这是一个钩子命令。当证书成功更新后,会执行deploy-hook后面指定的命令。

整个命令的作用:每天凌晨3点,自动检查证书是否需要更新(到期前30天内会自动更新),如果证书更新成功,则重新加载nginx配置,使新证书生效。

相关推荐
mCell8 小时前
如何零成本搭建个人站点
前端·程序员·github
我怎么又饿了呀15 小时前
如何上传本地文件到github仓库中入门教学
github
Jingzhou15 小时前
基于 AKShare 金融数据做了一个轻量级的金融研究 Agent
后端·github
淘矿人17 小时前
[特殊字符] 别再手动写提示词了!Claude Skills 10分钟入门,效率暴涨200%,Token狂省78%
人工智能·vscode·python·pycharm·github·文心一言·ai编程
逛逛GitHub19 小时前
GitHub 上狂揽 1.3 万 Star!港大开源的轻量版 Clawdbot。
github
云雾J视界20 小时前
当Agent接管代码后:产品经理的终极价值,是定义AI无法感知的“恐惧”与“爽点”
github·openai·copilot·ai产品经理·碳基情绪·硅基概率
WebInfra21 小时前
模块联邦 2.0 稳定版发布:兼顾开发效率与极致性能
前端·javascript·github
IT求学人1 天前
如何上传代码到github仓库
github
HelloGitHub1 天前
我装了个插件,让两个 OpenClaw 开始 24/7 搞事情了
开源·github
Light601 天前
GitHub Copilot提示词终极攻略:从“能用”到“精通”的AI编程艺术
github·copilot·ai编程·代码生成·提示词工程·开发效率·人机协作