Apache的性能优化(六)
Apache缺省的最大用户数是256个:这个配置对于服务器内存还是256M左右的时代是一个非常好的缺省设置,但随着内存成本的急剧下降,现在大型站点的服务器内存配置一般比当时要高一个数量级不止。所以256个进程的硬限制对于一台1G内存的机器来说是太浪费了,而且Apache的软上限 max_client是受限于HARD_SERVER_LIMIT的,因此如果WEB服务器内存大于256M,都应该调高Apache的 HARD_SERVER_LIMIT。根据个人的经验:2560已经可以满足大部分小于2G内存的服务器的容量规划了
一个apache + mod_php的服务器:一个apache进程一般需要4M内存
因此在一个1G内存的机器上:apache_max_process_with_good_perfermance < (1g / 4m) * 2 = 500
apache_max_process = 500 * 1.5 = 750
所以规划你的应用让服务尽量跑在500个进程以下以保持比较高的效率,并设置Apache的软上限在800个。
例子2:
一个apache + mod_resin的服务器: 一个apache进程一般需要2M内存
在一个2G内存的机器上:
apache_max_process_with_good_perfermance < (2g / 2m ) * 2 = 2000
apache_max_process = 2000 * 1.5 = 3000
--prefix=/another_driver/apache/:建议将apache服务安装在另外一个驱动设备上的目的在于硬盘往往是一个系统使用寿命最低的设备,因此:将服务数据和操作系统完全分开,不仅能提高了数据的访问速度,更重要的,大大方便系统升级,应用备份和恢复过程。
--shared-module=max:使用这种动态加载方式载入子模块会带来5%的性能下降.但给标准化安装和维护带来的好处也远比这多。我们的应用比较固定建议使用静态的。
grep -v "#" httpd.conf.default >httpd.conf
#最大服务进程数:根据服务容量预测设置
MaxClients 256 => 800
其他apache性能优化配置:
HostnameLookups off
On会带来延迟,因为对每一个请求都需要作一次DNS查询。
Options FollowSymLinks
为了得到最佳性能,并放弃对符号连接的保护,可以在需要的地方都设置FollowSymLinks, 而放弃使用SymLinksIfOwnerMatch.
AllowOverride None
如果URL空间允许覆盖(通常是用.htaccess文件), 则Apache会试图对每一个文件名组成部分打开.htaccess.
DirectoryIndex index.cgi index.pl index.shtml index.html
其中最常用的应该放在前面. 不要用通配符而使用完整的列表.
EnableMMAP off
在Apache 2.0需要搜索被发送文件的内容时,比如处理服务器端包含时, 如果OS支持某种形式的mmap(2),则会对此文件执行内存映射。
在某些平台上,内存映射可以提高性能,但是在某些情况下, 内存映射会降低性能甚至影响到httpd的稳定性.我们这个应用则关闭对发送文件的内存映射比较合适。
mod_status 和 ExtendedStatus Off
如果Apache在编译时包含了mod_status, 而且在运行时设置了ExtendedStatus On,则, 对每个请求Apache都会调用两次gettimeofday(2) (或者根据操作系统的不同,调用times(2)), 以及(pre-1.3)几个额外的time(2)调用,使状态记录带有时间标志。 为了得到最佳性能,可以设置ExtendedStatus off (这也是默认的).
调整 TCP 连接切断参数
在 /etc/sysctl.conf 中加入:
net.inet.tcp.msl=2000
net.inet.tcp.always_keepalive=0
上述设置将防止TCP连接默认以Keep Alive方式建立,并避免大量的空闲连接消耗OS
资源;此外,TCP TIME_WAIT的等待时间也从60秒减少到4秒。
调整 UFS dirhash 允许的内存用量
vfs.ufs.dirhash_maxmem=67108864 (此设置在5.3p14中已经自动包括)
这一设置将OS默认值提高32倍。
在 Apache 配置中禁用 KeepAlive:
编辑 /usr/local/etc/apache2/httpd.conf,将
KeepAlive On
改为
KeepAlive Off
在负载较大的服务器上,上述设置将把同时联到 httpd 上的连接从大约2200降低到400
以下。并有效改善响应时间。此前(大约3周)已经在部分机器上应用了上述设置,目前
为止基本可以确认这些设置不会造成可以为用户所感知的不良影响,同时会改善服务的
响应时间,因此建议在线的全部系统均应用上述设置。
具体技术细节
目前在线上的 FreeBSD 5.3 版本(无论patchlevel)的SINAMAIL内核中均联入了
ACCF_HTTP,其作用是在来自客户的HTTP请求完成之后再将其发给应用程序,从而降低
由于客户端网络较慢导致httpd过早开始等待连接所造成的资源消耗。
禁用KeepAlive之后,客户端在请求多个资源时,将有更大机会发出并发的请求。从
而,由于链路发生丢包等问题而发生的延迟对于下载其他资源的影响将会削弱。缩短
TCP分片超时之后,等待连接关闭的时间将缩短,并使建立的连接更趋稳定。
默认的dirhash最大内存为2MB。目前在生产系统上获得的实际用量通常在16-20MB左
右。将其扩大将改善同一目录下的文件的访问性能。
简单性能测试:(建议对配置各种参数分别测试,找出最佳优化参数)
用apache自己带的ab,进行测试的方法,如需要自己测试下就可以了。
[yangbin1@vHost-RH9 apache]$ ./bin/ab -n 10000 -c 100 http://10.210.128.189:7981/
This is ApacheBench, Version 2.0.40-dev <$Revision: 1.121.2.8 $> apache-2.0
Copyright (c) 1996 Adam Twiss, Zeus Technology Ltd, http://www.zeustech.net/
Copyright (c) 1998-2002 The Apache Software Foundation, http://www.apache.org/
Benchmarking 10.210.128.189 (be patient)
Completed 1000 requests
Completed 2000 requests
Completed 3000 requests
Completed 4000 requests
Completed 5000 requests
Completed 6000 requests
Completed 7000 requests
Completed 8000 requests
Completed 9000 requests
Finished 10000 requests
Server Software: Apache/2.0.49
Server Hostname: 10.210.128.189
Server Port: 7981
Document Path: /
Document Length: 1456 bytes
Concurrency Level: 100
Time taken for tests: 20.756253 seconds
Complete requests: 10000
Failed requests: 0
Write errors: 0
Total transferred: 19192048 bytes
HTML transferred: 14653184 bytes
Requests per second: 481.78 [#/sec] (mean)
Time per request: 207.563 [ms] (mean)
Time per request: 2.076 [ms] (mean, across all concurrent requests)
Transfer rate: 902.96 [Kbytes/sec] received
Connection Times (ms)
min mean[+/-sd] median max
Connect: 0 78 60.7 99 554
Processing: 20 125 57.8 114 1149
Waiting: 5 111 53.2 104 869
Total: 47 204 84.4 214 1303
Percentage of the requests served within a certain time (ms)
50% 214
66% 218
75% 220
80% 223
90% 264
95% 302
98% 447
99% 530
100% 1303 (longest request)
测试结果分析:暂时没有。
以上就是Apache的性能优化(六)的内容,更多相关内容请关注PHP中文网(www.php.cn)!
上一篇: Swift开发iOS应用(1)列表的实现
下一篇: python中线程与进程的区别与优劣