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

相关推荐
一个程序猿老马10 小时前
012、远程协作:连接GitHub/Gitee与git remote
git·gitee·github
小柯博客13 小时前
STM32MP2安全启动技术深度解析
c语言·c++·stm32·嵌入式硬件·安全·开源·github
zhensherlock13 小时前
Protocol Launcher 系列:Tally 快速计数器的深度集成
前端·javascript·typescript·node.js·自动化·github·js
darkb1rd21 小时前
OpenMythos:从零重构大模型架构实战指南
开源·github·好物分享
弑神风21 小时前
GitHub Copilot vs Cursor深度横评(2026):谁是AI编程之王?
程序员·github·copilot·ai编程·cursor·工具测评
CoderJia程序员甲21 小时前
GitHub 热榜项目 - 日榜(2026-04-25)
ai·大模型·llm·产品运营·github·ai教程
zh_xuan1 天前
把Android Library 上传到github并在工程中引用该远程仓库
android·github·远程仓库
盖丽男1 天前
使用 GitHub Actions 自动打包 Android APK
android·github
七颗糖很甜1 天前
预警!超级厄尔尼诺即将登场:2026-2027年全球气候或迎“极端狂暴模式”
java·大数据·python·算法·github
zhensherlock1 天前
Protocol Launcher 系列:Working Copy 文件操作与高级命令详解
javascript·git·typescript·node.js·自动化·github·js