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

Nginx版本平滑迁移方案

Nginx版本平滑迁移方案

  1. 最可靠方案make install后,先-s stop再重启,100%确保版本切换
  2. 特殊情况:当发现nginx.pid.oldbin文件时,才考虑使用USR2信号无损升级
  3. 避坑重点make install只是替换文件,必须重启才能加载新版本

查看内存中的nginx版本 (直接sbin目录下./nginx -v 无法保证绝对准确 ):
( r e a d l i n k / p r o c / (readlink /proc/ (readlink/proc/(cat /usr/local/nginx/logs/nginx.pid 2>/dev/null || pgrep -f “nginx: master” | head -1)/exe) -v 2>&1

升级过程:./configure ****** ,只是做了依赖库以及安装路径配置 、不影响现运行的nginx

其次就是:make也不影响 ,make仅编译 、还有make install 仅会替换nginx中的nginx ,如果和旧版路径不一样 、完全不影响


📌 标准升级流程(推荐所有用户)

1. 安全停止旧版本

make install 后,会生成新的nginx文件  、这个时候./nginx -v显示是新版,但内存中是旧版、所以需要stop 然后重启# 强制停止Nginx(会中断连接)
sudo /usr/local/nginx/sbin/nginx -s stop# 确认进程已退出
ps aux | grep nginx | grep -v grep

2. 启动新版本

sudo /usr/local/nginx/sbin/nginx# 验证新版本
/usr/local/nginx/sbin/nginx -v

3. 双重验证

# 检查内存中实际运行的版本
$(readlink /proc/$(cat /usr/local/nginx/logs/nginx.pid)/exe) -v# 检查网络响应版本
curl -sI http://localhost | grep Server

⚠️ 特殊情况处理

当出现nginx.pid.oldbin

# 1. 使用USR2信号启动新进程
sudo kill -USR2 $(cat /usr/local/nginx/logs/nginx.pid)# 2. 等待5秒(观察error.log是否出现新worker)
tail -f /usr/local/nginx/logs/error.log# 3. 优雅关闭旧进程
sudo kill -QUIT $(cat /usr/local/nginx/logs/nginx.pid.oldbin)

🔍 关键问题解答

Q:为什么不能直接make install就完成升级?

A:因为Linux运行的是内存中的进程,磁盘文件替换不影响已运行的程序

Q:哪些版本会产生nginx.pid.oldbin?

A:Nginx 1.11.6+ 且编译时未禁用--with-pid-path选项的版本

Q:如何确认是否需要USR2方案?

# 检查PID目录是否有写权限
test -w /usr/local/nginx/logs && echo "可用USR2方案" || echo "需stop-restart"

💀 必须避免的三大错误

误用-s reload

sudo nginx -s reload  # 只重载配置,不切换版本!

不验证真实版本

nginx -v  # 只显示磁盘文件版本,非运行版本!

直接kill进程

sudo pkill nginx  # 会导致请求中断!

🛡️ 回滚方案

# 1. 恢复旧版二进制
sudo cp /usr/local/nginx/sbin/nginx.old /usr/local/nginx/sbin/nginx# 2. 重启服务
sudo /usr/local/nginx/sbin/nginx -s stop
sudo /usr/local/nginx/sbin/nginx

📊 操作对比表

操作方式版本切换连接中断复杂度推荐场景
stop + restart✅ 是❌ 是所有常规升级
USR2信号✅ 是✅ 否⭐⭐⭐出现.pid.oldbin时

✅ 最佳实践总结

  1. 常规升级:直接stop+restart最可靠
  2. 特殊场景:发现nginx.pid.oldbin时才用USR2方案
  3. 必须验证:用/proc/$PID/exe确认内存中的真实版本

记住:make install只是开始,重启才是切换的关键!

http://www.lryc.cn/news/2391707.html

相关文章:

  • WPF 按钮悬停动画效果实现
  • 满天星之canvas实现【canvas】
  • 我在架构师面前谈 Spring Inner Beans,他直接点头说:这人有料!
  • Java无序数组 vs 有序数组:性能对比与选型指南
  • 【Linux 基础知识系列】第二篇-Linux 发行版概述
  • 【开源解析】基于PyQt5+Folium的谷歌地图应用开发:从入门到实战
  • 在 Ubuntu 22.04 LTS 上离线安装 Docker
  • python调用langchain实现RAG
  • Qt 中的 d-pointer 与 p-pointer小结
  • 冷库耗电高的一种重要原因分析,以及一种降低冷库电费≥20%的方法
  • 理解 Redis 事务-21(使用事务实现原子操)
  • 神经网络加上注意力机制,精度反而下降,为什么会这样呢?注意力机制的本质是什么?如何正确使用注意力机制?注意力机制 | 深度学习
  • 触控精灵 ADB运行模式填写电脑端IP教程
  • uniapp|实现多端图片上传、拍照上传自定义插入水印内容及拖拽自定义水印位置,实现水印相机、图片下载保存等功能
  • linux有效裁剪视频的方式(基于ffmpeg,不改变分辨率,帧率,视频质量,不需要三方软件)
  • 服务器密码安全运维解决新思路:凭据管理SMS+双因素SLA认证结合的方案
  • 论文阅读笔记——In-Context Edit
  • Debian 系统 Python 开发全解析:从环境搭建到项目实战
  • Next.js 15 与 Apollo Client 的现代集成及性能优化
  • 【后端高阶面经:MongoDB篇】41、MongoDB 是怎么做到高可用的?
  • IO Vs NIO
  • offset 家族和 client 家族
  • DMBOK对比知识点整理(4)
  • day12 leetcode-hot100-21(矩阵4)
  • Java基础 Day24
  • 提问:鲜羊奶是解决育儿Bug的补丁吗?
  • 关于数据仓库、数据湖、数据平台、数据中台和湖仓一体的概念和区别
  • Hive 分桶(Bucketing)深度解析:原理、实战与核心概念对比
  • 网络协议DHCP
  • 什么是可重组机器人?