Apache工作模式详解
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工作模式详解相关推荐
- 摘抄--apache工作模式详解
服务器优化配置 Apache的主要优势就是能更好地支持多处理器,在编译时通过使用--with-mpm选项来决定Apache的工作模式.如果知道当前的Apache使用的工作机制,则可以通过httpd - ...
- linux apache两种工作模式详解
apache两种工作模式详解 刚接触这两个配置时很迷糊,全部开启或全部注释没有几多变化.今天搜索到这么一篇讲得还不错的文章,看了几篇,还是不能完全记住,做一个收藏. 空闲子进程:是指没有正在处理请求的 ...
- 无线Wifi模块AP和STA工作模式详解
无线Wifi模块AP和STA工作模式详解 Wifi模块包括两种工作模式AP和STA,在这两模式的支持下,无线图传产品可以实现一发多收的功能.下面我们就从AP和STA的基本概念开始了解它们. 一.AP和 ...
- ST MCU_GPIO的八种工作模式详解
GPIO的八种工作模式详解 浮空输入_IN_FLOATING 带上拉输入_IPU 带下拉输入_IPD 模拟输入_AIN 开漏输出_OUT_OD 推挽输出_OUT_PP 开漏复用输出_AF_OD 推挽复 ...
- V90 PN伺服EPOS回零+点动JOG+MDI+程序步具体工作模式详解
V90 PN伺服EPOS回零+点动JOG+MDI+程序步具体工作模式详解 1. 回零 增量式编码器主动回零 在配置回零参数界面,选择回参考点方式: 0:信号REF 即直接设定参考点方式(将当前位置 ...
- RabbitMQ工作流程和工作模式详解
RabbitMQ工作流程 生产者发送消息的流程 生产者连接RabbitMQ,建立TCP连接( Connection),开启信道(Channel) 生产者声明一个Exchange(交换器),并设置相关属 ...
- LVS工作原理以及三种工作模式详解
1.负载均衡LVS基本介绍 LB集群的架构和原理很简单,就是当用户的请求过来时,会直接分发到Director Server上,然后它把用户的请求根据设置好的调度算法,智能均衡地分发到后端真正服务器(r ...
- Linux下snort的运行模式,Snort工作模式详解
Snort有3种工作模式,分别为嗅探器模式.分组数据包记录模式与网络**检测模式. m 嗅探器模式. Snort使用Libpcap包捕获库.在该模式下,Snort使用网络接口的混杂模式读取并解 ...
- SELinux的三种工作模式详解
目录 前言 一.SELinux是什么 二.CentOS 6.x 7.x安装SELinux 三.SELinux的主要作用 四.SELinux 的工作模式(Disabled.Permissive和Enfo ...
最新文章
- NLTK命名实体识别NER
- SAP Retail MM42不能修改物料的物料组
- java -cp 和 java -jar 的区别
- Oracle 安装报错 [INS-06101] IP address of localhost could not be determined 解决方法
- (11.06)Java小知识
- C#隐藏桌面图标和任务栏
- easyui源码翻译1.32--ValidateBox(验证框)
- 选定用户与用户组启动流程(学习笔记)
- c++ new 数组_用Java实现JVM第八章《数组和字符串》
- jsp 页面中文乱码解决(笔记)
- linux ubuntu安装svn,在Ubuntu下安装SVN工具RabbitVCS
- 2021年西式面点师(中级)考试题库及西式面点师(中级)考试试题
- c语言流水灯程序详细讲解,用c语言编写单片机流水灯程序详解
- python数据分析前景如何_数据分析师的前景怎么样?
- 吴恩达机器学习 EX7 第二部分 主成分分析(PCA)
- 微量元素检测仪产品功能及特点
- 【安全牛学习笔记】w3af
- RAM和ROM和Flash ROM的区别
- java 中输入字符的方法(顺便判断元音辅音)
- [蓝桥杯][2013年第四届真题]带分数(DFS,next_permutation两种方法)
热门文章
- PTA19、通过两个列表构建字典 (10 分)
- qr二维码遇到的一些问题
- php设置表格边框颜色,HTML表格标记教程(38):表头的边框色属性BORDERCOLOR
- 计算机网络基础文档,计算机网络基础-20210608152532.pdf-原创力文档
- IP计算机取证,计算机取证1资料.doc
- finalshell连接失败解决方法_iPhone热点连不上?教你网络连接失败或断线的解决办法...
- vue组件的按需加载
- 关于(我们流量表优化),分区表数据块过多,聚合又导致数据倾斜问题
- POJ 1692 Crossed Matchings dp[][] 比较有意思的dp
- 【转】ArcGIS Server安装