Nginx热升级流程
一、整体流程
- 备份旧的Nginx二进制文件,然后将旧Nginx二进制文件换成新的Nginx二进制文件
- 向master进程发送USR2信号
- master收到USR2信号后,修改pid文件名,加上后缀.oldbin
- master进程使用新的Nginx文件启动新的master进程,此时新老的Nginx共存并且同时处理请求
- 向老的master进程发送QUIT信号,老maseter进程对老的worker进程进行优雅关闭,然后关闭Nginx进程
- 回滚:向老的master发送HUP,向新master发送QUIT
整体流程如下图所示:
需要注意的是,新的MASTER进程是老的MASTER进程通过创建子进程的方式创建的
二、优雅关闭Worker进程
讨论Nginx的优雅关闭时,因为Master不处理请求,因此其实是在讨论Nginx对Worker进程的优雅关闭。
优雅关闭的流程
- 设置定时器,也就是worker_shutdown_timeout
- 关闭监听句柄
- 关闭空闲连接
- 在循环中等待全部连接关闭
- 退出进程
第四步中,只有当连接中的请求都处理完时才能关闭连接,目前只能判断HTTP请求。为了等待连接中的请求都处理完毕,可能会出现超过步骤一中设定的超时时间,此时,会立即退出Worker进程