优化Apache,提高并发

http://www.yuansir-web.com/2011/10/24/%E4%BC%98%E5%8C%96apache%EF%BC%8C%E6%8F%90%E9%AB%98%E5%B9%B6%E5%8F%91/


Apache 配置:

1. 模拟并发访问
ab -n 100000 -c 1000 -k http://weibo.cnsuning.com/index.php
在其它机器启动测试程序,也可以使用其它性能更强的并发测试工具

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

StartServers       8
MinSpareServers    32
MaxSpareServers   64
ServerLimit      10240
MaxClients       10000
MaxRequestsPerChild  10000

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. 关闭不需要的模块
注释掉加载该模块,及相关配置项


你可能感兴趣的:(apache)