Nginx实现平滑升级

前言

随着 Nginx 越来越流行,并且 Nginx 的优势也越来越明显,Nginx 的版本迭代也开起了加速模式。新版本也带来了新的功能,例如 stream 四层代理功能等,伴随着 Nginx 的广泛应用,版本升级必然越来越快。一般有两种情况下需要升级 Nginx:一种是确实要升级 Nginx 的版本,另一种是要为 Nginx 添加新的模块。

一、Nginx平滑升级原理

  • 在不停掉老进程的情况下,启动新进程。
  • 老进程负责处理仍然没有处理完的请求,但不再接受处理请求。
  • 新进程接受新请求。
  • 老进程处理完所有请求,关闭所有连接后,停止。

二、Nginx信号

(1)主进程支持的信号

  • TERM,INT:立刻退出;
  • QUIT:等待工作进程结束后再退出;
  • KILL:强制终止进程;
  • HUP:重新加载配置文件,使用新的配置启动工作进程,并逐步关闭旧进程;
  • USR1:重新打开日志文件;
  • USR2:启动新的主进程,实现热升级;
  • WINCH:逐步关闭工作进程。

(2)工作进程支持的信号

  • TERM,INT:立刻退出;
  • QUIT:等待请求处理结束后再退出;
  • USR1:重新打开日志文。

三、平滑升级实战

3.1 Nginx添加新模块

在已安装Nginx(我这里是编译安装)的基础上添加–with-http_image_filter_module模块。

(1)进入Nginx解压目录

[root@nginx-proxy ~]# cd /usr/local/nginx-1.18.0/

(2)查看Nginx已安装的模块

[root@nginx-proxy nginx-1.18.0]# /usr/local/nginx/sbin/nginx -V
nginx version: nginx/1.18.0
built by gcc 4.8.5 20150623 (Red Hat 4.8.5-39) (GCC) 
configure arguments: --prefix=/usr/local/nginx --pid-path=/var/run/nginx/nginx.pid --lock-path=/var/lock/nginx.lock --error-log-path=/var/log/nginx/error.log --http-log-path=/var/log/nginx/access.log --with-http_gzip_static_module --http-client-body-temp-path=/var/temp/nginx/client --http-proxy-temp-path=/var/temp/nginx/proxy --http-fastcgi-temp-path=/var/temp/nginx/fastcgi --http-uwsgi-temp-path=/var/temp/nginx/uwsgi --http-scgi-temp-path=/var/temp/nginx/scgi

(3)添加新模块

实际就是在Nginx已有的模块的基础上,再在最后添加–with-http_image_filter_module,最后再通过./configure进行编译。

[root@nginx-proxy nginx-1.18.0]# ./configure --prefix=/usr/local/nginx --pid-path=/var/run/nginx/nginx.pid --lock-path=/var/lock/nginx.lock --error-log-path=/var/log/nginx/error.log --http-log-path=/var/log/nginx/access.log --with-http_gzip_static_module --http-client-body-temp-path=/var/temp/nginx/client --http-proxy-temp-path=/var/temp/nginx/proxy --http-fastcgi-temp-path=/var/temp/nginx/fastcgi --http-uwsgi-temp-path=/var/temp/nginx/uwsgi --http-scgi-temp-path=/var/temp/nginx/scgi --with-http_image_filter_module

在这里插入图片描述
(4)进行make操作

按照原来的编译参数安装 nginx 的方法进行安装,只需要到 make,千万不要 make install 。如果make install 会将原来的配置文件覆盖。下面给Nginx添加–with-http_image_filter_module模块。

[root@nginx-proxy nginx-1.18.0]# make

在这里插入图片描述
(5)备份原Nginx二进制文件

/usr/local/nginx/sbin/nginx(期间nginx不会停止服务)

[root@nginx-proxy nginx-1.18.0]# mv /usr/local/nginx/sbin/nginx /usr/local/nginx/sbin/nginx.bak

(6)复制新的nginx二进制文件,进入新的nginx源码包

[root@nginx-proxy nginx-1.18.0]# cp /usr/local/nginx-1.18.0/objs/nginx /usr/local/nginx/sbin/

(7)测试新版本的nginx是否正常

[root@nginx-proxy nginx-1.18.0]# /usr/local/nginx/sbin/nginx -t
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful

(8)给nginx发送平滑迁移信号

若不清楚Nginx.pid的路径,可查看nginx配置文件,里面有对应的路径。

[root@nginx-proxy logs]# kill -USR2 `cat /usr/local/nginx/logs/nginx.pid`

(9)查看nginx pid,会出现一个nginx.pid.oldbin

即在补停掉老进程的情况下启动新进程。

[root@nginx-proxy ~]# ll /usr/local/nginx/logs/
total 8
-rw-r--r-- 1 root root 5 Sep 25 13:32 nginx.pid
-rw-r--r-- 1 root root 5 Sep 25 13:27 nginx.pid.oldbin

(10)从容关闭旧的Nginx进程

[root@nginx-proxy ~]# kill -WINCH `cat /usr/local/nginx/logs/nginx.pid.oldbin`

(11)结束工作进程,完成此次升级

[root@nginx-proxy ~]# kill -QUIT `cat /usr/local/nginx/logs/nginx.pid.oldbin`

(12)验证Nginx是否升级成功

[root@nginx-proxy ~]# /usr/local/nginx/sbin/nginx -V

在这里插入图片描述

3.2 Nginx版本升级

先安装配置1.6版本的Nginx(编译安装)用于测试。

3.2.1 安装Nginx1.6

(1)下载Nginx1.6/1.18版本包

[root@zrs ~]# wget http://nginx.org/download/nginx-1.6.3.tar.gz
[root@zrs ~]# wget http://nginx.org/download/nginx-1.18.0.tar.gz

(2)安装依赖环境

[root@zrs ~]# yum install -y gcc gcc-c++ pcre-devel openssl-devel zlib-devel

(3)进行安装

[root@zrs ~]# tar zxf  nginx-1.6.3.tar.gz -C /usr/local/
[root@zrs ~]# cd /usr/local/nginx-1.6.3/
[root@zrs nginx-1.6.3]# ./configure --prefix=/usr/local/nginx --user=nginx --group=nginx --with-http_stub_status_module
[root@zrs nginx-1.6.3]# make && make install
[root@zrs nginx-1.6.3]# useradd -M -s /sbin/nologin nginx

(4)启动Nginx服务

[root@zrs nginx-1.6.3]# /usr/local/nginx/sbin/nginx      #启动Nginx服务
[root@zrs nginx-1.6.3]# netstat -lntp | grep 'nginx'     #检测是否开启
tcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      3633/nginx: master
[root@zrs nginx-1.6.3]# /usr/local/nginx/sbin/nginx -t   #检测Nginx的配置是否正确
nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok
nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful

(5)查看Nginx版本和模块

[root@zrs nginx-1.6.3]# /usr/local/nginx/sbin/nginx -V
nginx version: nginx/1.6.3
built by gcc 4.8.5 20150623 (Red Hat 4.8.5-39) (GCC) 
configure arguments: --prefix=/usr/local/nginx --user=nginx --group=nginx --with-http_stub_status_module
3.2.2 升级Nginx1.6

将 nginx1.6版本进行升级(升级为Nginx1.18版本)并在不影响业务的情况下添加 SSL 和 pcre 模块。

(1)升级

[root@zrs ~]# tar xzf nginx-1.18.0.tar.gz -C /usr/local/
[root@zrs ~]# cd /usr/local/nginx-1.18.0/
[root@zrs nginx-1.18.0]# ./configure --prefix=/usr/local/nginx --user=nginx --group=nginx --with-http_stub_status_module --with-http_ssl_module --with-pcre   #升级并添加相关模块

(2)进行make

注意:这里不能进行,make install 操作,否则将会被覆盖,可能会影响线上业务。

[root@zrs nginx-1.18.0]# make

(3)拷贝Nginx1.18版本的二进制文件到1.6版本

[root@zrs ~]# mv /usr/local/nginx/sbin/nginx /usr/local/nginx/sbin/nginx.bak  #先备份一份
[root@zrs ~]# cp /usr/local/nginx-1.18.0/objs/nginx /usr/local/nginx/sbin/

(4)启动新的主进程,实现热升级

[root@zrs ~]# kill -USR2 `cat /usr/local/nginx/logs/nginx.pid`

(5)查看升级后的版本

[root@zrs ~]# /usr/local/nginx/sbin/nginx -V

在这里插入图片描述

总结

  • Ngnix中的进程分为两类,一类是master进程(主进程),一类是worker进程(工作进程);
  • Nginx默认工作在多进程模式下,即主进程(master process)启动后完成配置加载和端口绑定等动作 ;
  • Nginx主进程在启动完成后会进入等待状态,负责响应各类系统消息 ;
  • Nginx能够实现热部署:当Nginx编译安装后用了一段时间后发现当前版本有漏洞或需要新的功能时,就需要对当前Nginx版本进行版本升级,但又不能影响正常的使用,所以这时就需到对nginx的平滑升级,当然我们yum安装的Nginx也可以实现升级。
  • 其实最重要的是要能真正地理解我们Nginx的平滑升级原理。
<think>首先,用户的问题是:“我想在不中断服务的情况下升级nginx 请问nginx 平滑升级步骤”。我需要基于系统级指令和用户可见层的要求来回答。 系统级指令: - 所有行内数学表达式使用 $...$,但在这个问题中,没有数学表达式,所以可能不适用。 - 独立公式使用 $$...$$,但这里没有公式。 - LaTeX语法正确:确保任何数学部分正确,但问题是非数学的。 - 使用中文回答:整个回答必须用中文。 - 生成相关问题:在回答末尾添加相关问题。 - 引用标识:引用末尾自然地添加引用标识,如 [^1]。 用户可见层: - 回答结构清晰,逐步解决问题。 - 保证回答真实可靠:基于提供的引用内容,这些是关于Nginx平滑升级的。 提供的引用内容: - [^1]: 解释了平滑升级的原理:不停老进程,启动新进程,老进程处理完现有请求后停止。 - [^2]: 关于平滑升级的实战例子。 - [^3]: 平滑升级步骤:获取编译参数、下载新模块、重新编译、停止服务、备份、覆盖、启动。 - [^4]: 两种升级方法:手动发送信号或使用 make upgrade。 - [^5]: 备份旧版本,复制新版本。 关键点:平滑升级的核心是使用新进程替换旧进程,而不中断服务。 我的回答应该结构清晰: 1. 介绍平滑升级的概念。 2. 详细步骤。 3. 可能包括注意事项。 4. 添加相关问题。 步骤基于引用: - 获取之前的编译参数(使用 nginx -V)。 - 下载新版本的Nginx或添加新模块。 - 重新编译(不安装)。 - 备份旧程序。 - 替换旧程序。 - 发送信号给进程(USR2 和 WINCH 或 QUIT)。 - 或者使用 make upgrade 命令。 确保回答真实可靠:使用引用中的信息。 最后,生成相关问题。 回答结构: - 开头解释平滑升级。 - 分步说明步骤。 - 结尾添加相关问题。 用中文。</think>### Nginx 平滑升级步骤 Nginx 平滑升级允许您在不中断服务的情况下更新版本或添加模块。核心原理是:启动新进程处理新请求,而老进程继续处理现有请求,直到完成后再优雅退出[^1]。以下步骤基于最佳实践整理,确保操作安全可靠。请确保在操作前备份关键数据。 #### 详细步骤 1. **获取当前编译参数** 在升级前,获取当前 Nginx 的编译参数,确保新版本配置一致。 ```bash nginx -V ``` 输出结果包括 `configure arguments`(如 `--prefix=/usr/local/nginx`),记录这些参数用于后续编译[^3]。 2. **下载新版本或模块** - 下载新版本的 Nginx 源码包(如从官方站点获取)。 ```bash wget https://nginx.org/download/nginx-1.24.0.tar.gz tar -zxvf nginx-1.24.0.tar.gz cd nginx-1.24.0 ``` - 如果需要添加新模块,确保下载模块源码并解压到指定路径[^3]。 3. **重新编译新版本** 使用记录的编译参数重新编译,但不安装(避免直接覆盖)。 ```bash ./configure <您的编译参数> --add-module=<模块路径> # 例如:--add-module=/path/to/new_module make # 仅编译,不执行 make install ``` 编译后,新可执行文件位于 `objs/nginx`[^3][^4]。 4. **备份旧程序** 停止新请求接收,备份旧 Nginx 可执行文件,防止升级失败时回滚。 ```bash mv /usr/local/nginx/sbin/nginx /usr/local/nginx/sbin/nginx.old ``` 备份后,旧进程仍在运行,继续处理现有请求[^5]。 5. **替换为新程序** 复制新编译的 Nginx 文件到安装目录。 ```bash cp objs/nginx /usr/local/nginx/sbin/nginx ``` 6. **发送信号升级进程** 有两种方法可选(推荐方法一,更灵活): - **方法一:手动发送信号** 1. 发送 `USR2` 信号给主进程,启动新进程: ```bash kill -USR2 $(cat /usr/local/nginx/logs/nginx.pid) ``` 此时,新进程开始接受新请求,老进程继续处理旧请求[^1][^4]。 2. 发送 `WINCH` 信号让老进程优雅停止接受新连接: ```bash kill -WINCH $(cat /usr/local/nginx/logs/nginx.pid.oldbin) # 注意:pid.oldbin 是老进程的 PID 文件 ``` 3. 等待老进程处理完所有请求后,发送 `QUIT` 信号完全退出: ```bash kill -QUIT $(cat /usr/local/nginx/logs/nginx.pid.oldbin) ``` - **方法二:使用 make upgrade 命令** 在 Nginx 源码目录执行: ```bash make upgrade # 自动处理信号发送和进程切换 ``` 此命令简化了过程,但需确保编译路径正确[^4]。 7. **验证升级结果** - 检查版本: ```bash nginx -v ``` - 查看进程状态: ```bash ps aux | grep nginx ``` 新进程应正常运行,无错误日志(检查 `/var/log/nginx/error.log`)[^2]。 #### 注意事项 - **测试环境验证**:先在测试服务器模拟升级,避免生产环境风险。 - **回滚准备**:如果升级失败,用备份的 `nginx.old` 替换并重启服务。 - **依赖问题**:如果新版本依赖库(如 OpenSSL),确保系统已更新[^3]。 - **平滑升级失败处理**:常见原因包括 SSL 模块不兼容,检查编译参数是否匹配[^4]。 通过以上步骤,您可以实现零宕机升级,确保服务连续性。更多细节可参考 Nginx 官方文档或社区实践[^1][^2]。
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

云计算-Security

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值