Nginx 的reload,热升级以及优雅的关闭流程
一、reload流程
- 向master进程发送HUP信号(reload命令)
- master进程校验配置语法是否正确;
- master打开可能引入的新的监听端口;
- master用新的配置文件启动新的worker子进程;
- 启动新的worker子进程之后,master向老的worker子进程发送QUIT信号(优雅的退出);
- 老的子进程收到QUIT信号之后,关闭监听句柄(也就是说,新的连接只会到新的子进程),处理完当前的连接后就结束进程;
二、热升级的流程
-
将久的Nginx文件替换成新的Nginx文件(注意备份);
-
向master进程发送USR2信号;
Nginx还没有提供相应的命令行
-
之后,现有的master进程会修改pid文件名,加后缀oldbin;
这是为了给新的master进程让路;
-
老的master进程,用新的Nginx二进制文件,启动新的master进程;
此时,会出现两个master进程和老的worker进程。新的master进程会启动新的worker进程
-
向老的master进程发送QUIT信号,关闭老的进程;
此时老的master进程会关闭老的worker进程。此时,热升级已经结束,老的master进程会一直保留,这是为了方便回滚。
-
回滚:向老的master进程发送HUP,向新的master发送QUIT;
<

本文详细介绍了Nginx的reload流程,包括向master进程发送HUP信号,验证配置,启动新worker子进程并优雅关闭旧进程。接着讨论了热升级步骤,涉及替换Nginx文件,发送USR2信号,启动新master进程,并最终关闭旧进程。此外,还阐述了Nginx的优雅关闭机制,主要针对worker进程,确保处理完当前连接后再关闭,特别提到了在处理WebSocket等长连接时的局限性。

被折叠的 条评论
为什么被折叠?



