作者:mobiledu2502924873 | 来源:互联网 | 2023-05-17 02:13
http 请求在服务器处理中一般分为3段, 第一段header,第二段body,第三段响应。服务器先处理header,查看有没有content-length指明有没有body, 如果有body,继续下一个读事件,处理body,处理完body就会发送一个http响应。 如图中process中的三段处理.
apache 是采用阻塞机制, 且一个进程只处理一个请求,如图如果process1 处理 header请求网络事件不满足,则切换到process2 去执行绿色请求,如果绿色请求依然不满足,就会切换到process3 去执行橙色请求. 每个进程之间切换需要消耗5ms时间,当请求并发增加时,消耗时间成指数性增加,进程之间切换的消耗就不可忽视,容易导致阻塞。
nginx 在时间片时间内(在5ms-800ms之间),当请求网络事件不满足时,nginx直接在当前process内切换请求直到分配的时间片消耗完毕。 所以一般我们会在nginx配置时把worker的优先级调到最高-19(优先级数字在-20~20之间,-20为最高)从而使worker 分配的时间片尽可能多,从而尽可能少的切换process,让cpu少做无用功。
worker_priority number 设置Worker进程的静态优先级
Syntax: worker_priority number;
Default: worker_priority 0;
Context: main#如果不设置优先级
[root@www nginx-1.16.1]# ps -le | awk 'NR==1 || $14=="nginx"'
F S UID PID PPID C PRI NI ADDR SZ WCHAN TTY TIME CMD
0 S 0 18203 1 0 80 0 - 5174 sigsus ? 00:00:00 nginx
5 S 998 20923 18203 4 80 0 - 11958 ep_pol ? 00:00:00 nginx
5 S 998 20924 18203 5 80 0 - 11958 ep_pol ? 00:00:00 nginx
5 S 998 20925 18203 5 80 0 - 11958 ep_pol ? 00:00:00 nginx
5 S 998 20926 18203 3 80 0 - 11958 ep_pol ? 00:00:00 nginx#设置优先级之后
[root@www nginx-1.16.1]# ps -le | awk 'NR==1 || $14=="nginx"'
F S UID PID PPID C PRI NI ADDR SZ WCHAN TTY TIME CMD
0 S 0 18203 1 0 80 0 - 5174 sigsus ? 00:00:00 nginx
5 S 998 20478 18203 0 61 -19 - 11958 ep_pol ? 00:00:00 nginx
5 S 998 20479 18203 0 61 -19 - 11958 ep_pol ? 00:00:00 nginx
5 S 998 20480 18203 0 61 -19 - 11958 ep_pol ? 00:00:00 nginx
5 S 998 20481 18203 0 61 -19 - 11958 ep_pol ? 00:00:00 nginx
在Linux和Unix中,当许多进程都处于可执行状态时,按照优先级来决定本次内核选择哪一个进程执行。进程分配的CPU时间片大小也与优先级有关,优先级越高,时间片越长。
指明worker进程的nice值 -20-19,在Nginx的worker配置上面会将worker优先级配置到最高级别,比如-19。这样静态优先级高那么操作系统往往给其分配的时间片比较大,这样Nginx才能比较好的在用户态完成请求的切换使用CPU少做无用功,减少请求切换能够使得Nginx性能更高。