Nginx平滑升级1.41记录

本文介绍了一种针对老版本Nginx存在的溢出漏洞的解决方案——平滑升级。文章详细展示了整个过程:从下载并备份新旧版本,到编译安装新版本,最后逐步替换旧版本,确保服务不中断。
今天早上看到新闻,号称老版本nginx存在溢出漏洞。所以尝试一下nginx所谓的平滑升级。

(1)准备工作
下载新版本 备份老版本的sbin/nginx 为nginx.old

(2)编译新版本nginx
使用sbin/nginx -V查看曾经的编译配置信息 复制configure的参数
对新版本的nginx进行configure 参数使用之前的

make && make install安装

(3)平滑升级
kill -USR2 nginx进程号 //启动新版本nginx进程作为子进程,并且不停止老版本nginx。老版本nginx进程号存入nginx.pid.oldbin 新版本的掌管 nginx.pid

kill -WINCH 老版本进程号 //逐渐停止老版本的服务 worker进程渐渐关闭
kill -QUIT 老版本进程号 //worker进程关闭后 老版本退出 平滑升级成功
Nginx平滑升级(也称为热升级)是一种在不停止服务的情况下更新Nginx版本或添加模块的方法。这种升级方式确保了服务的高可用性,避免了因升级导致的请求中断问题。以下是实现Nginx平滑升级的具体步骤: ### 1. 下载并编译新版本Nginx 首先,需要下载目标版本的Nginx源码包,并解压。进入解压后的目录后,使用与当前运行版本相同的配置参数进行编译,同时可以添加新的模块或修改配置参数以满足需求。 ```bash # 下载新版本Nginx wget http://nginx.org/download/nginx-1.20.0.tar.gz tar -zxvf nginx-1.20.0.tar.gz cd nginx-1.20.0 # 使用与旧版本相同的配置参数进行编译,可通过nginx -V命令查看当前运行的配置参数 ./configure --prefix=/usr/local/nginx --with-http_ssl_module --add-module=../some-module make ``` ### 2. 替换旧的Nginx二进制文件 编译完成后,`objs/nginx`即为新的Nginx可执行文件。将其替换掉旧的Nginx二进制文件,通常位于`/usr/local/nginx/sbin/`目录下。 ```bash cp /path/to/nginx-1.20.0/objs/nginx /usr/local/nginx/sbin/ ``` ### 3. 发送USR2信号给Nginx主进程 通过向Nginx主进程发送USR2信号,触发平滑升级过程。这将启动新的Nginx进程,使用新的二进制文件,同时保留旧的进程以处理尚未完成的请求。 ```bash kill -USR2 `cat /usr/local/nginx/logs/nginx.pid` ``` ### 4. 关闭旧的Nginx进程 一旦确认新版本的Nginx已经成功启动并正常工作,可以通过发送WINCH信号给旧的主进程,让其关闭所有连接并退出。这个过程可能需要一些时间,具体取决于当前正在处理的请求数量。 ```bash kill -WINCH `cat /usr/local/nginx/logs/nginx.pid.oldbin` ``` ### 5. 验证升级 最后,验证Nginx是否已成功升级到新版本,并检查是否有任何错误或异常情况。 ```bash /usr/local/nginx/sbin/nginx -v ``` ### 注意事项 - 在执行平滑升级之前,建议备份现有的Nginx配置文件和二进制文件,以便于出现问题时快速回滚。 - 确保在编译新版本时使用的配置参数与旧版本一致,否则可能导致配置不兼容的问题。 - 如果在升级过程中遇到问题,可以通过发送HUP信号给Nginx主进程来重新加载旧的配置文件,或者直接恢复备份的二进制文件[^3]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值