第二章 nginx信号量

2.1 nginx命令行参数

不像许多其他软件系统,Nginx 仅有几个命令行参数,完全通过配置文件来配置

./nginx -c </path/to/config> 为 Nginx 指定一个配置文件,来代替缺省的。
./nginx -t 不运行,而仅仅测试配置文件。nginx 将检查配置文件的语法的正确性,并尝试打开配置文件中所引用到的文件。
./nginx -v 显示 nginx 的版本。
./nginx -V 显示 nginx 的版本,编译器版本和配置参数。

2.2 nginx控制信号

说明 :可以使用信号系统来控制主进程。默认,nginx 将其主进程的 pid 写入到 /usr/local/nginx/nginx.pid 文件中。通过传递参数给 ./configure 或使用 pid 指令,来改变该文件的位置。

2.2.1 进程信号使用列表

下标 名称 功能
1 TERM INT 快速关闭
2 QUIT 从容关闭
3 HUP 重载配置
4 USR1 重新打开日志文件
5 USR2 平滑升级可执行程序
6 WINCH 从容关闭工作进程

注释:在4~6中是指用新的配置开始新的工作进程并且从容关闭旧的工作进程

2.2.2 nginx进程说明

1
2
3
4
root@iZuf66hara3tw540cd2g5kZ:~# ps aux | grep nginx
root 7413 0.0 0.1 31936 3256 ? Ss Feb04 0:00 nginx: master process
./nginx -c ./nginx.conf
nobody 8702 0.0 0.1 32364 2984 ? S 00:32 0:00 nginx: worker process

如上所示ps aux | grep nginx表示查询nginx进程。由上面我们可以看出存在两个nginx进程,nginx: masternginx: worker process
master和worker的区别和联系

  • master:表示是主进程,worker;表示正在运行中的子进程。
  • 一个主进程管理若干个子进程,当子进程完成整个工作流程时,主进程将负责告诉子进程进行自动释放,同时主进程将继续产生一个新的子进程。
  • 主进程被杀死,所有对应的子进程也将消失。所以作为一个程序员尤其是一个运维不能随意的用
  • 不可以随意Kill+进程号这样杀掉子进程。

举例说明 :例如当消费者正在提交订单,付款时,突然进程被杀死,你却支付一半的钱,但是订单没有完成,因此订单不会被写入到服务器上,商家也就不会发货。

2.3 nginx进程信号分析

  1. TERM INT

说明 :这个表示尽快杀死,不建议使用

1
代码 :kill -INT 7413   ./sbin/nginx/ -s stop
  1. QUIT

说明 :优雅的杀掉进程,假如你执行完kill QUIT 7413,支付进程只有在你付完款才会被杀掉,

1
代码 :kill -QUIT 7413    ./sbin/nginx/ -s quit
  1. HUB

说明 :优雅的杀掉旧进程,然后开启新进程,不需要像tomcat一样改了配置文件后要想加载新的进程就要重新启动一下服务器

1
代码 :kill -HUP  7413 或者 ./sbin/nginx/ -s roload
  1. USER1

说明 :这个信号多用于日志备份切割,一般nginx是通过一个个knode指向磁盘从而进行日志并进行备份。要想每天备份一份日志,需要进行结点的切割(kill -USER1 ‘cat logs/nginx.pid’),将结点连接到新的日志文件上.尤其是运维,公司老板可能会要求你每天晚上备份日志文件,第二天用一个新的日志文件继续运行

1
代码 :kill -USER1  7413   或者 ./sbin/nginx/ -s reopen

注释 ‘cat logs/nginx.pid’指获取进程号

  1. USER2 和 WINCH

你可以在不中断服务的情况下 - 新的请求也不会丢失,使用新的 nginx 可执行程序替换旧的(当升级新版本或添加/删除服务器模块时)。

首先,使用新的可执行程序替换旧的(最好做好备份),然后,发送 USR2 (kill -USR2 pid)信号给主进程。主进程将重命名它的 .pid 文件为 .oldbin (比如:/usr/local/nginx/logs/nginx.pid.oldbin),然后执行新的可执行程序,依次启动新的主进程和新的工作进程:

1
2
3
4
5
6
7
8
9
 PID   PPID USER    %CPU   VSZ WCHAN  COMMAND
33126 1 root 0.0 1164 pause nginx: master process /usr/local/nginx/sbin/nginx
33134 33126 nobody 0.0 1368 kqread nginx: worker process (nginx)
33135 33126 nobody 0.0 1380 kqread nginx: worker process (nginx)
33136 33126 nobody 0.0 1368 kqread nginx: worker process (nginx)
36264 33126 root 0.0 1148 pause nginx: master process /usr/local/nginx/sbin/nginx
36265 36264 nobody 0.0 1364 kqread nginx: worker process (nginx)
36266 36264 nobody 0.0 1364 kqread nginx: worker process (nginx)
36267 36264 nobody 0.0 1364 kqread nginx: worker process (nginx)

在这时,两个 nginx 实例会同时运行,一起处理输入的请求。要逐步停止旧的实例,你必须发送 WINCH 信号给旧的主进程,然后,它的工作进程就将开始从容关闭:

1
2
3
4
5
6
7
PID    PPID USER    %CPU   VSZ WCHAN  COMMAND
33126 1 root 0.0 1164 pause nginx: master process /usr/local/nginx/sbin/nginx
33135 33126 nobody 0.0 1380 kqread nginx: worker process is shutting down (nginx)
36264 33126 root 0.0 1148 pause nginx: master process /usr/local/nginx/sbin/nginx
36265 36264 nobody 0.0 1364 kqread nginx: worker process (nginx)
36266 36264 nobody 0.0 1364 kqread nginx: worker process (nginx)
36267 36264 nobody 0.0 1364 kqread nginx: worker process (nginx)

一段时间后,旧的工作进程处理了所有已连接的请求后退出,就仅由新的工作进程来处理输入的请求了:

1
2
3
4
5
6
 PID   PPID USER    %CPU   VSZ WCHAN  COMMAND
33126 1 root 0.0 1164 pause nginx: master process /usr/local/nginx/sbin/nginx
36264 33126 root 0.0 1148 pause nginx: master process /usr/local/nginx/sbin/nginx
36265 36264 nobody 0.0 1364 kqread nginx: worker process (nginx)
36266 36264 nobody 0.0 1364 kqread nginx: worker process (nginx)
36267 36264 nobody 0.0 1364 kqread nginx: worker process (nginx)

这时,因为旧的服务器还尚未关闭它监听的套接字,所以,通过下面的几步,你仍可以恢复旧的服务器:

  • 发送 HUP 信号给旧的主进程 - 它将在不重载配置文件的情况下启动它的工作进程
  • 发送 QUIT 信号给新的主进程,要求其从容关闭其工作进程
  • 发送 TERM 信号给新的主进程,迫使其退出
  • 如果因为某些原因新的工作进程不能退出,向其发送 KILL 信号
    新的主进程退出后,旧的主进程会由移除 .oldbin 前缀,恢复为它的 .pid 文件,这样,一切就都恢复到升级之前了。

如果尝试升级成功,而你也希望保留新的服务器时,发送 QUIT 信号给旧的主进程使其退出而只留下新的服务器运行:

1
2
3
4
5
PID  PPID USER    %CPU   VSZ WCHAN  COMMAND
36264 1 root 0.0 1148 pause nginx: master process /usr/local/nginx/sbin/nginx
36265 36264 nobody 0.0 1364 kqread nginx: worker process (nginx)
36266 36264 nobody 0.0 1364 kqread nginx: worker process (nginx)
36267 36264 nobody 0.0 1364 kqread nginx: worker process (nginx)

2.4 nginx 启动、停止、重启命令

2.4.1 nginx启动

1
sudo /usr/local/nginx/nginx     (nginx二进制文件绝对路径,可以根据自己安装路径实际决定)

2.4.2 nginx从容停止命令,等所有请求结束后关闭服务

1
2
3
ps -ef |grep nginx

kill -QUIT nginx主进程号

2.4.3 nginx 快速停止命令,立刻关闭nginx进程

1
2
3
ps -ef |grep nginx

kill -TERM nginx主进程号

2.4.4 如果以上命令不管用,可以强制停止

1
kill -9 nginx主进程号

如果嫌麻烦可以不用查看进程号,直接使用命令进行操作
其中/usr/local/nginx/nginx.pid 为nginx.conf中pid命令设置的参数,用来存放nginx主进程号的文件
kill -信号类型(HUP|TERM|QUIT) cat /usr/local/nginx/nginx.pid
例如

1
2
3
kill -QUIT `cat /usr/local/nginx/nginx.pid`
1
kill -QUIT `cat /usr/local/nginx/nginx.pid`

2.5 nginx重启命令

nginx重启可以分成几种类型

1.简单型,先关闭进程,修改你的配置后,重启进程。

1
2
kill -QUIT cat /usr/local/nginx/nginx.pid
sudo /usr/local/nginx/nginx
评 论