如何测试和调试Linux的Apache服务器

2008-02-23 08:20:44来源:互联网 阅读 ()

新老客户大回馈,云服务器低至5折

  Apache是运行在Linux操作系统上的头号Web服务器。很多小地方都能够用来调整Apache的性能,并降低他对系统资源的影响。其中一个就是调整内存使用率,当然达到这一目的可能还是需要花点功夫的。

  例如,通过ps来确定httpd线程的内存使用率,能够输入下面的命令:

  # ps -U apache -u apache u

  USERPID %CPU %MEMVSZRSS TTYSTAT START TIME COMMAND

  apache130670.05.3 149704 54504 ?SOct071:53 /usr/sbin/httpd -f /etc/httpd/conf/httpd.conf -DAPACHE2

  ...

  上面这段输出显示了单个httpd进程使用了50 MB的RSS(驻留集大小)内存(或非交换物理内存),连同149 MB的VSZ(虚拟)内存。这当然在很大程度上取决于您在Apache里加载和运行的模块数量。这决不是个固定的数字。由于这个数字里还包含了共享库包,所以不是100%的准确。能够认为RSS数字的一半是httpd线程真正使用的内存数,这可能更有点保守,但是离目的已很接近。

  在本文里,假设每个httpd进程都在使用了27 MB内存。然后,需要确定能够让httpd真正使用的内存数。根据运行在机器上的其他进程,您可能希望需要50%的物理内存都供Apache使用。在一个装有1GB内存的系统上,就有512MB的内存能够被划分为多个27MB的内存,也就是大约19个并发的httpd内存。有些人坚持认为每个httpd 线程“真正”使用大约5MB的内存,所以从理论上讲能够把512MB的内存划分出102个并发进程供Apache使用(要记住的是,除非您的网站需要极其巨大的流量,否则这种情况是很罕见的)。

  在默认状态下,Apache会分配最大256个并发客户端连接,或256个进程(每一个都对应一个请求)。按照这种配置,一个流量巨大的网站会在顷刻间崩溃(即使假设每个进程占用5MB内存,那也需要1.3GB的内存来满足请求的数量)。假如不采取其他措施,系统会通过硬盘来尝试使用交换空间以处理他无法在物理内存中完成的任务。

  其他能够调整的项目包括KeepAlive、KeepAliveTimeout和MaxKeepAliveRequests等配置。能够放在httpd.conf文档里的推荐配置有:

  ServerLimit 128MaxClients 128KeepAlive OnKeepAliveTimeout 2MaxKeepAliveRequests 100

  通过将KeepAliveTimeout从15秒减到2秒,能够增加MaxClients命令;19太小,而128要好得多。通过减少进程存活的秒数,您能够在相同的时间内允许更多的连接。

  当然,假如没有真正的测试在背后支持,数字就是毫无意义的,这就是ab的作用之所在。使用ab对Apache配置文档(MaxClients等于 256、ServerLimit等于256、KeepAliveTimeout等于15)进行调整,使其能够满足1000个请求(100个连续请求并发产生)的调整方法如下。(在执行测试的时候要确保服务器上有一个终端打开以观察系统的负载。)

  $ ab -n 1000 -c 100 -k http://yoursite.com/index.php

  现在把上面的服务器配置改为更加保守的配置,重新启动Apache,试着再次测试(总是从远程电脑上进行,而不是本机)。

  在这里的测试中,不同的配置导致执行所消耗的时间产生了一倍的差距(分别为27.8s和16.8s),但是负载的平均值为0.03和0.30。这可能会使得您的网站变得稍慢,但是会确保他不会在高负载的情况下崩溃。还要记住的是,您将需要进行多次测试,以便取得一个平均值。

  使用ab是测试调整Apache配置的一个极佳方法,应该在您每次做出影响性能的更改时使用他。
  

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇: Web应用服务器优化方法

下一篇: 建立Web应用的一个新途径