2019独角兽企业重金招聘Python工程师标准>>>

prefork 工作模式

如果httpd -l列出prefork.c。则表示是 prefork 工作方式。 如下面所示:    
Compiled in modules:    
  core.c    
  prefork.c    
  http_core.c    
  mod_so.c

这表明当前apache2的工作方式是 prefork

prefork的工作原理是,控制进程在最初建立“StartServers”个子进程后,为了满足MinSpareServers设置的需要创建一个进程,等待一秒钟,继续创建两个,再等待一秒钟,继续创建四个……如此按指数级增加创建的进程数,最多达到每秒32个,直到满足MinSpareServers设置的值为止。这就是预派生(prefork)的由来。这种模式可以不必在请求到来时再产生新的进程,从而减小了系统开销以增加性能。

对于 prefork 工作模式的 apache 来说,在 httpd.conf(主配置文件) 中对它的设置是在

# prefork MPM    
# StartServers: number of server processes to start    
# MinSpareServers: minimum number of server processes which are kept spare    
# MaxSpareServers: maximum number of server processes which are kept spare    
# ServerLimit: maximum value for MaxClients for the lifetime of the server    
# MaxClients: maximum number of server processes allowed to start    
# MaxRequestsPerChild: maximum number of requests a server process serves    
<IfModule prefork.c>    
StartServers       8    
MinSpareServers    5    
MaxSpareServers   20    
ServerLimit      256    
MaxClients       256    
MaxRequestsPerChild  4000    
</IfModule>

ServerLimit  
默认的MaxClient最大是256个线程,如果想设置更大的值,就的加上ServerLimit这个参数。20000是ServerLimit这个参数的最大值。    
如果需要更大,则必须编译apache,此前都是不需要重新编译Apache。    
生效前提:必须放在其他指令的前面

StartServers  
指定服务器启动时建立的子进程数量,prefork默认为5。

MinSpareServers  
指定空闲子进程的最小数量,默认为5。如果当前空闲子进程数少于MinSpareServers ,那么Apache将以最大每秒一个的速度产生新的子进程。此参数不要设的太大。

MaxSpareServers  
设置空闲子进程的最大数量,默认为10。如果当前有超过MaxSpareServers数量的空闲子进程,那么父进程将杀死多余的子进程。    
此参数不要设的 太大。如果你将该指令的值设置为比MinSpareServers小,Apache将会自动将其修改成”MinSpareServers+1″。

MaxClients  
限定同一时间客户端最大接入请求的数量(单个进程并发线程数),默认为256。任何超过MaxClients限制的请求都将进入等候队列,一旦一个链接被释放,    队列中的请求将得到服务。要增大这个值,你必须同时增大ServerLimit。

MaxRequestsPerChild  
每个子进程在其生存期内允许伺服的最大请求数量,默认为10000.到达MaxRequestsPerChild的限制后,子进程将会结束。    
如果 MaxRequestsPerChild为”0″,子进程将永远不会结束。将MaxRequestsPerChild设置成非零值有两个好处:    
1.可以防止(偶然的)内存泄漏无限进行,从而耗尽内存。    
2.给进程一个有限寿命,从而有助于当服务器负载减轻的时候减少活动进程的数量。

按照前面的设置,在该工作模式下,服务器启动后起动8个httpd进程(加父进程共9个,通过 ps -ax|grep httpd命令可以看到)。    
当有用户连接时,apache会使用一个空闲进程为该连接服务,同时父进程会fork(复制)一个子进程。    
直到内存中的空闲进程达到MaxSpareServers。该模式是为了兼容一些旧版本的程序。缺省编译时的选项。

worker 工作模式

如果httpd -l列出worker.c ,类似如下,则表示是 worker 工作模式

Compiled in modules:  
  core.c    
  worker.c    
  http_core.c    
  mod_so.c

worker的工作原理是,由主控制进程生成“StartServers”个子进程,每个子进程中包含固定的ThreadsPerChild线程数,各个线程独立地处理请求。同样,为了不在请求到来时再生成线程,MinSpareThreads和MaxSpareThreads设置了最少和最多的空闲线程数;而MaxClients设置了所有子进程中的线程总数。如果现有子进程中的线程总数不能满足负载,控制进程将派生新的子进程。

这时候的配置文件如下:

# worker MPM  
# StartServers: initial number of server processes to start    
# MaxClients: maximum number of simultaneous client connections    
# MinSpareThreads: minimum number of worker threads which are kept spare    
# MaxSpareThreads: maximum number of worker threads which are kept spare    
# ThreadsPerChild: constant number of worker threads in each server process    
# MaxRequestsPerChild: maximum number of requests a server process serves    
<IfModule worker.c>    
StartServers         2    
MaxClients         150    
MinSpareThreads     25    
MaxSpareThreads     75    
ThreadsPerChild     25    
MaxRequestsPerChild  0    
</IfModule>

StartServers  
服务器启动时建立的子进程数,默认值是”3″。

MaxClients  
允许同时伺服的最大接入请求数量(最大线程数量)。任何超过MaxClients限制的请求都将进入等候队列。默认值是”400″ ,    16(ServerLimit)乘以25(ThreadsPerChild)的结果。因此要增加MaxClients的时候,你必须同时增加 ServerLimit的值。

MinSpareThreads  
最小空闲线程数,默认值是”75″。这个MPM将基于整个服务器监视空闲线程数。如果服务器中总的空闲线程数太少,子进程将产生新的空闲线程。

MaxSpareThreads  
设置最大空闲线程数。默认值是”250″。这个MPM将基于整个服务器监视空闲线程数。如果服务器中总的空闲线程数太多,子进程将杀死多余的空闲线程。    
MaxSpareThreads的取值范围是有限制的。Apache将按照如下限制自动修正你设置的值:    
worker要求其大于等于 MinSpareThreads加上ThreadsPerChild的和。

ThreadsPerChild  
每个子进程建立的常驻的执行线程数。默认值是25。子进程在启动时建立这些线程后就不再建立新的线程了。

MaxRequestsPerChild  
设 置每个子进程在其生存期内允许伺服的最大请求数量。到达MaxRequestsPerChild的限制后,子进程将会结束。如果 MaxRequestsPerChild为”0″,子进程将永远不会结束。将MaxRequestsPerChild设置成非零值有两个好处:    
1.可以防止(偶然的)内存泄漏无限进行,从而耗尽内存。    
2.给进程一个有限寿命,从而有助于当服务器负载减轻的时候减少活动进程的数量。    
注意对于KeepAlive链接,只有第一个请求会被计数。事实上,它改变了每个子进程限制最大链接数量的行为。

该模式是由线程来监听客户的连接。当有新客户连接时,由其中的一个空闲线程接受连接。  
服务器在启动时启动两个进程,每个进程产生的线程数是固定的 (ThreadsPerChild决定),因此启动时有50个线程。    
当50个线程不够用时,服务器自动fork一个进程,再产生25个线程。

转载于:https://my.oschina.net/leeypp1/blog/298790

Apache工作模式详解相关推荐

  1. 摘抄--apache工作模式详解

    服务器优化配置 Apache的主要优势就是能更好地支持多处理器,在编译时通过使用--with-mpm选项来决定Apache的工作模式.如果知道当前的Apache使用的工作机制,则可以通过httpd - ...

  2. linux apache两种工作模式详解

    apache两种工作模式详解 刚接触这两个配置时很迷糊,全部开启或全部注释没有几多变化.今天搜索到这么一篇讲得还不错的文章,看了几篇,还是不能完全记住,做一个收藏. 空闲子进程:是指没有正在处理请求的 ...

  3. 无线Wifi模块AP和STA工作模式详解

    无线Wifi模块AP和STA工作模式详解 Wifi模块包括两种工作模式AP和STA,在这两模式的支持下,无线图传产品可以实现一发多收的功能.下面我们就从AP和STA的基本概念开始了解它们. 一.AP和 ...

  4. ST MCU_GPIO的八种工作模式详解

    GPIO的八种工作模式详解 浮空输入_IN_FLOATING 带上拉输入_IPU 带下拉输入_IPD 模拟输入_AIN 开漏输出_OUT_OD 推挽输出_OUT_PP 开漏复用输出_AF_OD 推挽复 ...

  5. V90 PN伺服EPOS回零+点动JOG+MDI+程序步具体工作模式详解

    V90 PN伺服EPOS回零+点动JOG+MDI+程序步具体工作模式详解 1. 回零  增量式编码器主动回零 在配置回零参数界面,选择回参考点方式: 0:信号REF 即直接设定参考点方式(将当前位置 ...

  6. RabbitMQ工作流程和工作模式详解

    RabbitMQ工作流程 生产者发送消息的流程 生产者连接RabbitMQ,建立TCP连接( Connection),开启信道(Channel) 生产者声明一个Exchange(交换器),并设置相关属 ...

  7. LVS工作原理以及三种工作模式详解

    1.负载均衡LVS基本介绍 LB集群的架构和原理很简单,就是当用户的请求过来时,会直接分发到Director Server上,然后它把用户的请求根据设置好的调度算法,智能均衡地分发到后端真正服务器(r ...

  8. Linux下snort的运行模式,Snort工作模式详解

    Snort有3种工作模式,分别为嗅探器模式.分组数据包记录模式与网络**检测模式. m     嗅探器模式. Snort使用Libpcap包捕获库.在该模式下,Snort使用网络接口的混杂模式读取并解 ...

  9. SELinux的三种工作模式详解

    目录 前言 一.SELinux是什么 二.CentOS 6.x 7.x安装SELinux 三.SELinux的主要作用 四.SELinux 的工作模式(Disabled.Permissive和Enfo ...

最新文章

  1. NLTK命名实体识别NER
  2. SAP Retail MM42不能修改物料的物料组
  3. java -cp 和 java -jar 的区别
  4. Oracle 安装报错 [INS-06101] IP address of localhost could not be determined 解决方法
  5. (11.06)Java小知识
  6. C#隐藏桌面图标和任务栏
  7. easyui源码翻译1.32--ValidateBox(验证框)
  8. 选定用户与用户组启动流程(学习笔记)
  9. c++ new 数组_用Java实现JVM第八章《数组和字符串》
  10. jsp 页面中文乱码解决(笔记)
  11. linux ubuntu安装svn,在Ubuntu下安装SVN工具RabbitVCS
  12. 2021年西式面点师(中级)考试题库及西式面点师(中级)考试试题
  13. c语言流水灯程序详细讲解,用c语言编写单片机流水灯程序详解
  14. python数据分析前景如何_数据分析师的前景怎么样?
  15. 吴恩达机器学习 EX7 第二部分 主成分分析(PCA)
  16. 微量元素检测仪产品功能及特点
  17. 【安全牛学习笔记】w3af
  18. RAM和ROM和Flash ROM的区别
  19. java 中输入字符的方法(顺便判断元音辅音)
  20. [蓝桥杯][2013年第四届真题]带分数(DFS,next_permutation两种方法)

热门文章

  1. PTA19、通过两个列表构建字典 (10 分)
  2. qr二维码遇到的一些问题
  3. php设置表格边框颜色,HTML表格标记教程(38):表头的边框色属性BORDERCOLOR
  4. 计算机网络基础文档,计算机网络基础-20210608152532.pdf-原创力文档
  5. IP计算机取证,计算机取证1资料.doc
  6. finalshell连接失败解决方法_iPhone热点连不上?教你网络连接失败或断线的解决办法...
  7. vue组件的按需加载
  8. 关于(我们流量表优化),分区表数据块过多,聚合又导致数据倾斜问题
  9. POJ 1692 Crossed Matchings dp[][] 比较有意思的dp
  10. 【转】ArcGIS Server安装