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配置,使新证书生效。

相关推荐
用户0780625347197 小时前
纯前端实现 AI 抠图:我如何用 ONNX + Canvas 在浏览器里跑背景移除
github
白鲸开源7 小时前
干货!SeaTunnel(2.3.12)高阶用法(一):核心概念之数据流
java·大数据·github
逛逛GitHub7 小时前
Karpathy 加入 Anthropic 了,盘点他开源的 5 个硬核 GitHub 项目。
github
你的保护色7 小时前
RAID学习
github
ChampaignWolf7 小时前
GitHub Copilot 用于 SAP ABAP 在 VS Code 中:本地部署团队设置指南
github·copilot
VIV-8 小时前
Pycharm项目上传到Github
ide·pycharm·github
xG8XPvV5d8 小时前
GitHub Actions自动化部署全攻略
运维·自动化·github
ChampaignWolf10 小时前
GitHub 发布全新 Copilot 独立应用,正面硬刚 Claude Code 与 Codex
github·copilot
冴羽yayujs12 小时前
GitHub 热门项目-日榜(2026-05-19)
前端·javascript·github
梦梦代码精13 小时前
LikeShop开源多端商城系统:半年使用记录
git·uni-app·github