青铜棺有什么特别的:Apache MPM worker中的几个参数

来源:百度文库 编辑:九乡新闻网 时间:2024/04/27 17:59:07

     最近发现自己是个干杂活儿的人,因此把本博的名字都改成了“不求甚解”,纯粹都为了解决眼前的问题,这样的工作方式已经完完全全背离了自己的习惯。废话少说,切入正题,最近对Apache中的一些参数做了些了解,下面就记录一下我的理解。

  1. # worker MPM
  2. # ThreadLimit: maximum setting of ThreadsPerChild
  3. # ServerLimit: maximum setting of StartServers
  4. # StartServers: initial number of server processes to start
  5. # MaxClients: maximum number of simultaneous client connections
  6. # MinSpareThreads: minimum number of worker threads which are kept spare
  7. # MaxSpareThreads: maximum number of worker threads which are kept spare
  8. # ThreadsPerChild: constant number of worker threads in each server process
  9. # MaxRequestsPerChild: maximum number of requests a server process serves

  10. ThreadLimit 125
  11. ServerLimit 320
  12. StartServers 5
  13. MaxClients 8000
  14. MinSpareThreads 125
  15. MaxSpareThreads 1250
  16. ThreadsPerChild 125
  17. MaxRequestsPerChild 1000
其中最重要的参数是ThreadsPerChild和MaxClients:
  1. ##ThreadsPerChild 每个子进程建立的线程数,子进程在启动时建立这些线程后就不再建立新的线程了
  2. ##MaxClients 允许同时伺服的最大接入请求数量(在worker下就是最大线程数量)
    1. ##ServerLimit:对最大子进程数的上限,该值必须大于等于MaxClients/ThreadsPerChild
    2. ##ThreadLimit:对ThreadsPerChild的上限,该值必须大于等于 ThreadsPerChild,如果将ThreadLimit设置成一个高出实际需要很多的ThreadsPerChild值,将会有过多的共享内存被 分配,应当和ThreadsPerChild可能达到的最大值保持一致.
    3. ##StartServers:服务器启动时的服务进程数目,该值肯定小于等于ServerLimit
    4. ##MinSpareThreads和MaxSpareThreads:通过新建或结束子进程的方式,将空闲线程的总数维持在这个范围内
    5. ##MaxRequestsPerChild:用于控制服务器建立新进程和结束旧进程的频 率,其实是一个为了防止内存溢出的参数,每个子进程在其生存期内允许伺服的最大请求数量。到达MaxRequestsPerChild的限制后,子进程将 会结束。对于KeepAlive链接,只有第一个请求会被计数。事实上,它改变了每个子进程限制最大链接数量的行为。
    可以通过检查HTTPServer/logs/error_log日志,判断MaxClients是否需要增加,如果有下面的报错,就说明apache自上次重启至今,曾经发生过达到MaxClients的情况:

    1. Tue Jun 07 16:36:03 2011] [error] server reached MaxClients setting, consider raising the MaxClients setting
需要注意的是,这样的报错并不会出现多次,当第二次达到MaxClients时,error_log不会记录。
还有一种可以实时看到连接数的方法,就是打开server-status页面,设置方法如下:
1. 去掉以下部分的注释
  1. LoadModule status_module modules/mod_status.so

  2. ExtendedStatus On
2.修改以下部分

  1.     SetHandler server-status
  2.   # Order deny,allow
  3.   # Deny from all
  4.     Allow from all
重启ihs
使用:http://yourhost/server-status 可以进入监控页面
如果浏览器支持刷新,可以http://your_host/server-status?refresh=5 以便每 5 秒钟刷新一次

在打开的监控页面中:"." Open slot with no current process,这里面的单个进程的“.”的数量其实对应与ThreadLimit这个值。

  1. ThreadLimit 10
  2. ServerLimit 2
  3. StartServers 1
  4. MaxClients 2
  5. MinSpareThreads 1
  6. MaxSpareThreads 2
  7. ThreadsPerChild 1
  8. MaxRequestsPerChild 1
httpd.conf的MPM配置如上例,在监控页面中的输出如下,其中有2个进程,各10个ThreadLimit,但由于ThreadsPerChild的限制,其实很多.是没有用的。
  1. W........._.........