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

相关推荐
张居斜9 小时前
GitHub Actions + 阿里云 OSS:OIDC 免密同步构建产物
github·oss·llm-wiki
用户32283600844712 小时前
python-rapidjson:用 C++ 速度处理 JSON 的 Python 库
github
逛逛GitHub12 小时前
4 个比较实用的 GitHub 开源项目,浅浅的收藏一波。
github
Hommy8812 小时前
【剪映小助手】添加贴纸接口(Add Sticker)
后端·github·剪映小助手·视频剪辑自动化·剪映api
2601_9618451515 小时前
粉笔行测5000题电子版|pdf|解析
pdf·新媒体运营·github·个人开发·内容运营·规格说明书·极限编程
用户7735300845118 小时前
gorillamux:Go语言路由库的实用选择
github
BBWEYY终身尊贵会员19 小时前
2026年6月四款建站工具怎么选?BBWEYY、比文云、GitHub Copilot、Dreamweaver 简明对比
github·copilot·dreamweaver
DogDaoDao19 小时前
【GitHub】CL4R1T4S:AI 系统提示词的透明革命
人工智能·python·ai·大模型·github·ai agent·cl4r1t4s
CHENG-JustDoIt20 小时前
AI工具 | 爆火开源项目Odysseus AI 工作台:从项目介绍、部署情况及其使用等多方位分析指南(含详细步骤)
大数据·人工智能·windows·python·ai·开源·github
MicrosoftReactor20 小时前
技术速递|从一次性提示到标准化工作流:如何在 GitHub Copilot CLI 中使用自定义智能体
github·copilot·cli·智能体