2014-02-07 12:50:01
来 源
ITJS.CN
Apache
本文介绍优化Apache服务器提高并发性能和效率,希望对于初学Apache服务器相关的朋友有帮助,更多Apache安装、配置、报错处理等资源请本站内搜索。

Apache 配置:

1. 模拟并发访问

ab -n 100000 -c 1000 -k http://www.server110.com

在其它机器启动测试程序,也可以使用其它性能更强的并发测试工具

2. 检测HTTPD连接数:

watch -n 1 -d “pgrep httpd|wc -l”

3. 确定工作模式 prefork / worker

httpd -l

4. 并发参数设置

# 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    32

MaxSpareServers   64

ServerLimit      10240

MaxClients       10000

MaxRequestsPerChild  10000

</IfModule>

prefork的工作原理是,控制进程在最初建立”StartServers”个子进程后,

为了满足”MinSpareServers”设置的需要创建一个进程,

等待一秒钟,继续创建两个,再等待一秒钟,继续创建四个……如此按指数级增加创建的进程数,最多达到每秒32个,

直到满足 MinSpareServers设置的值为止。

这就是预派生(prefork)的由来。这种模式可以不必在请求到来时再产生新的进程,从而减小了系统开销以增加性能。

MaxSpareServers设置了最大的空闲进程数,如果空闲进程数大于这个值,apache会自动kill掉一些多余进程。

这个值不要设得过大,但如果设的值比MinSpareServers小,apache会自动把其调整为MinSpareServers+ 1。

如果站点负载较大,可考虑同时加大MinSpareServers和MaxSpareServers。

MaxRequestsPerChild设置的是每个子进程可处理的请求数。

每个子进程在处理了”MaxRequestsPerChild” 个请求后将自动销毁。

0意味着无限,即子进程永不销毁。虽然缺省设为0可以使每个子进程处理更多的请求,但如果设成非零值也有两点重要的好处:

可防止意外的内存泄漏;在服务器负载下降的时侯会自动减少子进程数。

因此,可根据服务器的负载来调整这个值。但也不能太小,不然系统不断的开启新的apache进程,造成资源浪费。

MaxClients是这些指令中最为重要的一个,设定的是apache可以同时处理的请求,是对apache性能影响最大的参数。

其缺省值 150是远远不够的,如果请求总数已达到这个值(可通过ps -ef|grep http|wc -l来确认),那么后面的请求就要排队,直到某个已处理请求完毕。

这就是系统资源还剩下很多而http访问却很慢的主要原因。

5. 其它参数设置

ServerTokens Prod – 隐藏服务器版本信息,只显示 apache

ServerSignature Off

HostnameLookups Off

Timeout 5 – 请求超时时间

KeepAlive On

KeepAliveTimeout 5

MaxKeepAliveRequests 100

6. 关闭不需要的模块

注释掉加载该模块,及相关配置项

声明: 此文观点不代表本站立场;转载须要保留原文链接;版权疑问请联系我们。