当前位置: 首页 > news >正文

网络安全实战nginx漏洞版本升级 1.28.0到1.30.0

下载版本地址:https://nginx.org/en/download.html

系统环境:ubuntu 24.04

一、下载并编译新版nginx

1.下载nginx1.30.0

wget https://nginx.org/download/nginx-1.30.0.tar.gz

2.解压

tar -zxvf nginx-1.30.0.tar.gz

3.移动到/usr/local目录(个人习惯也可以略过此步骤)

mv nginx-1.30.0 /usr/local/

4.先确定一下当前版本xinx

cd /usr/local/nginx/sbin/

./nginx -v

显示nginx version: nginx/1.28.0

5.编译新版本

cd /usr/local/nginx-1.30.0

./configure

继续执行make命令

执行成功以后,回在当前目录产生一个objs目录

注意事项:

编译产生物理路径:nginx/objs/nginx

禁止执行 make install 防止覆盖现有配置

出现 ./configure:error 需要检查缺失的依赖库

二、替换可执行文件,平滑升级

1.替换可执行文件

备份旧版本方便报错回滚

cp /usr/local/nginx/sbin/nginx /usr/local/nginx/sbin/nginx.bak

备份配置文件(可选)

cp -r /usr/local/nginx/conf /usr/local/nginx/conf.bak

将新编译的objs/nginx 复制到旧版本安装目录中

cp objs/nginx /usr/local/nginx/sbin/

注意此时操作会提示 cp: cannot create regular file ‘/usr/local/nginx/sbin/nginx’: Text file busy 。表面正在被运行的nginx进程占用。 需要先通过nginx平滑升级流程 处理旧进程,确保替换二进制文件时不会冲突。

2.进行平滑升级处理

获取旧版本nginx 主进程PID

cat /usr/local/nginx/logs/nginx.pid

发送USR2 信号启动新版本的master进程

kill -USR2 449621

此时,nginx 会启动新的master进程,并加载新版本配置文件,旧版本master进程仍然在运行,但新的master进程已经启动。

替换二进制文件

mv objs/nginx /usr/local/nginx/sbin/

关闭旧版本进程

发送winch信号,逐步关闭旧版本worker进程

kill -WINCH 449621

检查进程状态

ps -ef |grep nginx

此时旧的会话被新的nginx进程替代,在检查新nginx 不影响业务之后,就可以完全停止旧进程了

完全关闭旧版本master进程

kill -QUIT 449621

检查新版本是否运行

验证版本信息

/usr/local/nginx/sbin/nginx -v

回滚方案(如升级失败)

恢复备份文件

cp /usr/local/nginx/sbin/nginx.bak /usr/local/nginx/sbin/nginx

重启旧版本进程

kill -QUIT $(cat /usr/local/nginx/logs/nginx.pid)

启动旧版本nginx

/usr/local/nginx/sbin/nginx

http://www.jsqmd.com/news/686774/

相关文章:

  • 别再只会用CSS Transition了!用FLIP动画思想搞定复杂位移与缩放(以扭蛋机为例)
  • 2283 美元!AI 成功写出 Chrome Bug 利用链,未来黑客攻击门槛或持续下降
  • 别再死记硬背二分法了!用C++ STL的lower_bound/upper_bound实战刷题(附LeetCode例题)
  • 企庭实业:AI驱动的企业家多层次服务创新实践 - 资讯焦点
  • 2026年4月济南装修/全包装修/别墅装修/精装房装修/全屋定制公司哪家好 - 2026年企业推荐榜
  • AirPodsDesktop:在Windows和Linux上解锁苹果耳机完整体验的3大秘诀
  • AI将漏洞利用提速至分钟级,补丁窗口期彻底崩溃
  • 地图数据处理终极指南:Mapshaper 让地理信息处理变得简单快速
  • 别再被OpenAI的APIConnectionError卡住了!手把手教你用Python设置代理(附完整代码)
  • 用Git Bisect快速定位引入Bug的提交
  • 别再只会用Stegsolve了!CTFshow七夕杯LSB隐写题复盘:cloacked-pixel工具详解与emoji-AES新姿势
  • D3KeyHelper终极指南:5分钟掌握暗黑3自动化游戏技巧
  • 如何解决设计到动画的断层问题:AEUX跨平台工作流技术指南
  • 当你的STM32项目需要驱动10个IIC设备时,我是这样用C语言‘面向对象’重构软件IIC的
  • Real-Anime-Z效果展示:real-anime-z_21生成复古胶片颗粒+动漫线条作品
  • 2026年4月|填埋场隐患排查TOP8机构,守护环境安全防线 - 资讯焦点
  • 从攻击者视角看防御:我用Kali对自家网站做了一次CC压力测试,发现了这些安全盲点
  • 【glusterfs】EC落盘
  • 蚂蚁灵光豪掷1亿激励闪应用创作,便捷背后能否解决数据安全和用户留存难题?
  • PENS (Performance-Based Neighbor Selection)
  • 从‘码盘不准’到‘精准定位’:一个开源激光里程计标定工具包的保姆级使用指南(附ROS Noetic/Melodic配置)
  • 智能主机防护体系推荐:从资产清点到威胁响应 - 品牌2026
  • OpenClaw界面错乱、闪退问题,一键修复教程(附工具)
  • 为什么 92.7% 的 C# AOT 项目在接入 Dify 时触发了 CVE-2024-XXXX?你漏掉的第 3 步安全校验正在让 .aot.dll 成为攻击入口!
  • 代理IP可用率怎么测?3个硬核工具与脚本,开发者必看
  • 一文带你看懂,火爆全网的Skills到底是个啥
  • 2026硅胶处理剂厂家实力测评:靠谱厂商推荐与选型指南 - 博客湾
  • 告别安装失败!Windows 10/11 保姆级MySQL 8.0.12安装与配置全流程(含环境变量设置)
  • SeaTunnel + AI:一句“我要做什么”,能不能直接变成一份能跑的配置?
  • 论文AI率过高怎么办?2026年实测10款降AI工具,帮你低成本降低AI率 - 降AI实验室