Nginx与Apache请求切换对比
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性能更高。
相关文章
- java.lang.NoClassDefFoundError:org/apache/commons/lang/exception/NestableRuntimeException 异常的处理
- 如何正确地在Axis、Axis2和Apache CXF之间抉择?
- VS2015 Apache Cordova第一个Android和IOS应用
- Apache http 包中的常量
- linux下apache服务器的安装、启动、查看
- Nginx 0.8.x + PHP 5.2.13(FastCGI)搭建胜过Apache十倍的Web服务器(第6版)[原创]
- 使用Apache FtpServer搭建FTP服务器 [FlashFXP]
- Apache几种限制ip的方法
- Apache Shiro 认证过程
- Exception in thread “main“ java.lang.NoClassDefFoundError: org/apache/spark/sql/SparkSession$
- 深度对比Apache CarbonData、Hudi和Open Delta三大开源数据湖方案
- java.lang.NullPointerException Ignoring exception during close for org.apache.hadoop.mapred.MapTask$NewOutputCollector@1398c56
- apache ab工具对网站进行压力测试
- 为什么Nginx性能比Apache高
- linux上配置jdk+Apache
- Nginx:承受3万并发连接数,胜过Apache 10倍
- phpstudy下载、安装、配置、网站部署、卸载(windows下php、apache、nginx环境测试)
- Root cause: BlockMissingException【查看修复HDFS中丢失的块】ORG.APACHE.HADOOP.HDFS.BLOCKMISSINGEXCEPTION: COULD
- mac apache php mysql nginx php接口的简单demo
- 06 - vulhub - Apache HTTPD 多后缀解析漏洞
- 千亿级、大规模:腾讯超大 Apache Pulsar 集群性能调优实践
- Apache Kafka 基本操作