zl程序教程

您现在的位置是:首页 >  工具

当前栏目

Nginx与Apache请求切换对比

ApacheNginx 请求 对比 切换
2023-09-14 09:01:46 时间

http 请求在服务器处理中一般分为3段, 第一段header,第二段body,第三段响应。服务器先处理header,查看有没有content-length指明有没有body, 如果有body,继续下一个读事件,处理body,处理完body就会发送一个http响应。 如图中process中的三段处理.

                                                             apache任务切换

apache 是采用阻塞机制, 且一个进程只处理一个请求,如图如果process1 处理 header请求网络事件不满足,则切换到process2 去执行绿色请求,如果绿色请求依然不满足,就会切换到process3 去执行橙色请求. 每个进程之间切换需要消耗5ms时间,当请求并发增加时,消耗时间成指数性增加,进程之间切换的消耗就不可忽视,容易导致阻塞。                
                                                                      nginx任务切换

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性能更高。