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