我们都了解apache的两种工作模式,这节我们以prefork模式来考虑apache应用的配置!首先说说apache的prefork工作模式:
prefork:特点稳定,对动态页面支持好!
prefork的工作原理是,控制进程在最初建立"StartServers"个子进程后,为了满足"MinSpareServers"设置的需要创建一 个进程,等待一秒钟,继续创建两个,再等待一秒钟,继续创建四个……如此按指数级增加创建的进程数,最多达到每秒32个,直到满足 MinSpareServers设置的值为止。这就是预派生(prefork)的由来。这种模式可以不必在请求到来时再产生新的进程,从而减小了系统开销 以增加性能。
MaxSpareServers设置了最大的空闲进程数,如果空闲进程数大于这个值,apache会自动kill掉一些多余进程。这个值不要设得过大,但 如果设的值比MinSpareServers小,apache会自动把其调整为MinSpareServers+ 1。如果站点负载较大,可考虑同时加大MinSpareServers和MaxSpareServers。
MaxRequestsPerChild设置的是每个子进程可处理的请求数。每个子进程在处理了"MaxRequestsPerChild" 个请求后将自动销毁。0意味着无限,即子进程永不销毁。虽然缺省设为0可以使每个子进程处理更多的请求,但如果设成非零值也有两点重要的好处:
a.可防止意外的内存泄漏;
b.在服务器负载下降的时侯会自动减少子进程数。
因此,可根据服务器的负载来调整这个值。但也不能太小,不然系统不断的开启新的apache进程,造成资源浪费。
MaxClients 是这些指令中最为重要的一个,设定的是apache可以同时处理的请求,是对apache性能影响最大的参数。其缺省值 150是远远不够的,如果请求总数已达到这个值(可通过ps -ef|grep http|wc -l来确认),那么后面的请求就要排队,直到某个已处理请求完毕。这就是系统资源还剩下很多而http访问却很慢的主要原因。系统管理员可以根据硬件配置 和负载情况来动态调整这个值。虽然理论上这个值越大,可以处理的请求就越多,但apache默认的限制不能大于256。如果把这个值设为大于256,那么 apache将无法起动。事实上,256对于负载稍重的站点也是不够的。
###################################################################
<IfModule prefork.c>
StartServers 8
MinSpareServers 5
MaxSpareServers 20
ServerLimit 256
MaxClients 256 一个服务器的绝不至于此!
MaxRequestsPerChild 4000
</IfModule>
###################################################################
看看下面的数据,我使用ab做压力测试:ab -c 500 -t 60 http://127.0.0.1/index.html
看看一个apache进程占多少内存:
看看top的man文档:注意这几列
o: VIRT -- Virtual Image (kb)
The total amount of virtual memory used by the task. It includes all
code, data and shared libraries plus pages that have been swapped out.
(Note: you can define the STATSIZE=1 environment variable and the VIRT
will be calculated from the /proc/#/state VmSize field.)
VIRT = SWAP + RES.
p: SWAP -- Swapped size (kb)
The swapped out portion of a task’s total virtual memory image.
q: RES -- Resident size (kb)
The non-swapped physical memory a task has used.
个人认为:swap可手动添加,而物理内存是主要的限制,可以看出一个httpd占3.3M, MaxClients数量便可以这样计算:
MaxClients = ( 物理内存*0.8 - 干净开机已使用内存 )/ 3.3M (注意要配置ServerLimit,MaxClients要小于ServerLimit)
oracle就是一个吃内存的数据库,开启是便分配上G内存给SGA,内部几个重要内存区可手动调整,在规划时,一定要注意系统的安全性与内存的使用率,(不了解的可以看看oracle的体系结构)
prefork:特点稳定,对动态页面支持好!
prefork的工作原理是,控制进程在最初建立"StartServers"个子进程后,为了满足"MinSpareServers"设置的需要创建一 个进程,等待一秒钟,继续创建两个,再等待一秒钟,继续创建四个……如此按指数级增加创建的进程数,最多达到每秒32个,直到满足 MinSpareServers设置的值为止。这就是预派生(prefork)的由来。这种模式可以不必在请求到来时再产生新的进程,从而减小了系统开销 以增加性能。
MaxSpareServers设置了最大的空闲进程数,如果空闲进程数大于这个值,apache会自动kill掉一些多余进程。这个值不要设得过大,但 如果设的值比MinSpareServers小,apache会自动把其调整为MinSpareServers+ 1。如果站点负载较大,可考虑同时加大MinSpareServers和MaxSpareServers。
MaxRequestsPerChild设置的是每个子进程可处理的请求数。每个子进程在处理了"MaxRequestsPerChild" 个请求后将自动销毁。0意味着无限,即子进程永不销毁。虽然缺省设为0可以使每个子进程处理更多的请求,但如果设成非零值也有两点重要的好处:
a.可防止意外的内存泄漏;
b.在服务器负载下降的时侯会自动减少子进程数。
因此,可根据服务器的负载来调整这个值。但也不能太小,不然系统不断的开启新的apache进程,造成资源浪费。
MaxClients 是这些指令中最为重要的一个,设定的是apache可以同时处理的请求,是对apache性能影响最大的参数。其缺省值 150是远远不够的,如果请求总数已达到这个值(可通过ps -ef|grep http|wc -l来确认),那么后面的请求就要排队,直到某个已处理请求完毕。这就是系统资源还剩下很多而http访问却很慢的主要原因。系统管理员可以根据硬件配置 和负载情况来动态调整这个值。虽然理论上这个值越大,可以处理的请求就越多,但apache默认的限制不能大于256。如果把这个值设为大于256,那么 apache将无法起动。事实上,256对于负载稍重的站点也是不够的。
###################################################################
<IfModule prefork.c>
StartServers 8
MinSpareServers 5
MaxSpareServers 20
ServerLimit 256
MaxClients 256 一个服务器的绝不至于此!
MaxRequestsPerChild 4000
</IfModule>
###################################################################
看看下面的数据,我使用ab做压力测试:ab -c 500 -t 60 http://127.0.0.1/index.html
看看一个apache进程占多少内存:
看看top的man文档:注意这几列
o: VIRT -- Virtual Image (kb)
The total amount of virtual memory used by the task. It includes all
code, data and shared libraries plus pages that have been swapped out.
(Note: you can define the STATSIZE=1 environment variable and the VIRT
will be calculated from the /proc/#/state VmSize field.)
VIRT = SWAP + RES.
p: SWAP -- Swapped size (kb)
The swapped out portion of a task’s total virtual memory image.
q: RES -- Resident size (kb)
The non-swapped physical memory a task has used.
个人认为:swap可手动添加,而物理内存是主要的限制,可以看出一个httpd占3.3M, MaxClients数量便可以这样计算:
MaxClients = ( 物理内存*0.8 - 干净开机已使用内存 )/ 3.3M (注意要配置ServerLimit,MaxClients要小于ServerLimit)
oracle就是一个吃内存的数据库,开启是便分配上G内存给SGA,内部几个重要内存区可手动调整,在规划时,一定要注意系统的安全性与内存的使用率,(不了解的可以看看oracle的体系结构)
来源:oschina
链接:https://my.oschina.net/u/817537/blog/145021