自动续期的免费ssl证书_薅羊毛

news/2024/12/15 0:01:41/文章来源:https://www.cnblogs.com/baimingqian/p/18607441

自建的个人网站使用了阿里的ssl证书,以前有一年有限期,现在被改为3个月有限期,费时费力每次要续期,某猫总是喵呜喊着“打钱”。

经济不景气,只能想办法找免费方便的方案。

方案是:Let's Encrypt三个月免费证书 + certbot证书安装续期工具 + cron任务

1,安装certbot工具包

sudo yum install certbot

2,检查一遍环境

查看版本:

certbot --version

检查Nginx是否已安装并正在运行:

sudo systemctl status nginx

检查Nginx配置文件语法:

sudo nginx -t

确认你要替换证书的域名解析是否正确:

ping blog.yeyangt.cn #替换为你自己的域名

3,执行命令将现有证书替换为新证书

sudo certbot --nginx --nginx-server-root /usr/local/nginx/conf --nginx-ctl /usr/local/nginx/sbin/nginx -d blog.yeyangt.cn  #替换为你自己的nginx路径和域名

 这个命令会自动申请证书,并且修改nginx的配置文件,然后执行nginx -s reload。执行这个命令会让你填入邮件,以及同意协议,一步步操作即可。

4,确认证书已经是新证书了

最简单的方案是在自己的网站上查看,从浏览器中打开自己的网站,然后点击锁标志,然后查看证书

 或者在nginx配置中查看证书

或者查看certbot的日志

less /var/log/letsencrypt/letsencrypt.log

5、自动更新证书的定时任务配置

A、 创建或编辑根用户的crontab
sudo crontab -e 
B、添加凌晨两点的renew任务:
0 2 * * * /usr/bin/certbot renew --quiet --deploy-hook "systemctl reload nginx"
C、保存并退出
D、验证cron任务
sudo crontab -l | grep certbot
E、测试自动续期配置
sudo certbot renew --dry-run 
#--dry-run:模拟续期过程,不会实际更改任何证书。用于测试配置是否正确。
F、日志查看
less /var/log/letsencrypt/letsencrypt.log

certbot renew解释下:
1、会首先检查已有的证书是否即将过期,如果证书仍在有效期内,且距离到期还有较长时间,它就不会再次申请新的证书。当证书接近到期时,certbot renew 才会真正向Let’s Encrypt申请新的证书。

2、它是非交互模式下运行,即会自动续期,不需要用户干预。

 

6、其它:为letsencrypt.log配上定时清理

清理方案不再写了,与证书更新流程无关,只是建议配置上

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/852734.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Logi Options Plus精简安装

✨Logi Options Plus精简安装 Logi Options Plus经常会需要更新,如果不点开更新就会在Launchpad出现“罗技语音”、“罗技AI”的图标 可以更新但不想经常出现这些图标,影响本人完美的Launchpad布局了解到一个GitHub Repository:Logi Options Plus Mini https://github.com/Q…

Java线程命名问题解决

前言 网上冲浪时刷到线程池的文章,想想看自己好像还没在实际场景中设置过线程名称,小小研究一下。 研究过程 默认命名 创建的线程都会有自己的名字,如果不设置,程序会给线程默认的名字,如Thread-0 Thread t = new Thread(() -> {System.out.println(Thread.currentThre…

差分约束系统,2-SAT

一.差分约束 问题是给定x1,x2,……,xn,然后给定出若干限制 xi-xj<=c,然后求解/无解 xi-xj>=c可以转换成xj-xi<=-c; xi-xj=c,可以转换为xi-xj<=c,xi-xj>=c;最暴力的想法就是一开始给所有的变量都赋值为0,然后每次都暴力循环所有的限制,如果有限制不满足,直接改变…

update一下

近日自己做的饭

Linux挂载机械硬盘raid操作说明

1.查看磁盘的信息,确认磁盘名 一般可以根据磁盘的大小来确认是那个,如图所示,是 /dev/md127lsblk 2.将磁盘的文件类型转化为exts,注意该操作将删除该磁盘所有的数据!!!!mkfs.ext4 /dev/md127 3.挂在目录,如果不存在先创建目录,这里为 /source 挂在完成后使用 df -h查…

Mind(基础入门篇)

对于在基础入门中所学习知识点做一总结。附:完整笔记目录~ ps:本人小白,笔记均在个人理解基础上整理,若有错误欢迎指正! 七、Mind(基础入门篇)

《Django 5 By Example》阅读笔记:p543-p550

《Django 5 By Example》学习第 19 天,p543-p550 总结,总计 8 页。 一、技术总结 1.fixtures (1)定义 A fixture is a collection of files that contain the serialized contents of the database.(2)作用 1)数据导入 一般来说,我们是通过数据库工具(如:Navicat,DBeaver)…

印象助手发布更新v1.2.4

本次发布印象助手v1.2.4的更新主要有对从enex转换出来的markdown(MD)文件进行编码修正. 例如MarginNote的笔记转到印象笔记(或者国际版Evernote)里, 再从印象笔记(Evernote)的enex转成markdown就会出现少许字符变成乱码, 这是MarginNote造成的. 本软件会尽最大努力进行修复, 但…

Ubuntu22.04 LTS 部署harbor-v2.7.2高可用

Ubuntu22.04 LTS 部署harbor高可用 一、harbor 环境部署 1. 下载harbor包 [root@harbor01:~]# wget https://github.com/goharbor/harbor/releases/download/v2.7.2/harbor-offline-installer-v2.7.2.tgz2. 解压软件包 [root@harbor01:~]# tar xf harbor-offline-installer-v2.…

PolarCTF-Pwn(困难)WP

1、ret2libc 前期准备:int __fastcall main(int argc, const char **argv, const char **envp) {char s[112]; // [rsp+0h] [rbp-70h] BYREFsetvbuf(stdin, 0LL, 2, 0LL);setvbuf(stdout, 0LL, 2, 0LL);setvbuf(stderr, 0LL, 2, 0LL);gets(s);puts(s);return 0; }因为程序是动…

游戏产业加速鸿蒙化步伐:超1800款鸿蒙原生游戏已上架

2024年度中国游戏产业年会于12月12日至13日北京市首钢国际会展中心举办,华为终端云全球生态发展与销售部副总裁张思建受邀出席主论坛,并发表了主题演讲。同期,由华为游戏中心主办的鸿蒙游戏行业论坛也在北京石景山区举行,本次活动邀请了中国音像与数字出版协会常务副理事长…