IT技术博客大学习 共学习 共进步
全部 移动开发 后端 数据库 AI 算法 安全 DevOps 前端 设计 开发者

apache httpd worker模式工作原理及配置

ZavaKid的博客 2011-01-29 22:05:46 累计浏览 3,763 次
本机暂存

httpd在linux下默认使用prefork, 我们网站的服务器,在编译httpd的时候,就指定了使用worker模式。

简单了解 worker模式与 prefork模式

worker : httpd在启动的时候,会由root进程派生出几个子进程,每个子进程中会有固定数量的线程,到时候提供服务的,就是这些线程,也就是说一个进程能够同时提供多次服务。

prefork : httpd使用进程来提供服务,每个进程在同一时间提供一次服务。

worker 参数配置

由于我比较关注 worker 模式, 所以就特别关注了一下 worker 的一些参数配置。

worker的参数主要有:ServerLimit,ThreadLimit,StartServers,MinSpareThreads,
MaxSpareThreads,ThreadsPerChild,MaxClients,MaxRequestsPerChild。

  • ServerLimit 是设置httpd root进程能够产生的最大进程数限制
  • ThreadLimit 是设置每个httpd子进程能够产生的最大服务线程限制
  • StarServers 是httpd刚启动时,root进程创建的子进程数
  • MinSpareThreads 顾名思义,就是最少的空闲线程数
  • MaxSpareThreads 就是最多的空闲线程数
  • ThreadsPerChild 每个子进程产生的线程数
  • MaxClients httpd同时处理的最大请求数
  • MaxRequestsPerChild 每个子进程提供的请求服务数,如果达到该值,则该子进程结束,由root进程根据需要再次派生新的子进程

其中几个参数之间的联系还是很重要的:

  • ServerLimit 限制了 MaxClients 和 ThreadsPerChild。 因为 MaxClients / ThreadsPerChild = 子进程数, 而子进程数目是受限于 ServerLimit
  • MaxSpareThreads 需要 大于等于 MinSpareThreads + ThreadsPerChild 。 根据我的理解,这也是合理的,因为子进程产生时,线程的数目已经是固定的了,那就需要 [ MinSpareThreads, MaxSpareThreads ] 中有一个线程数对ThreadsPerChild取余能够为0。
下面看看 worker模式下这些参数的默认配置值 :
<IfModule worker.c>
     ServerLimit      16
     ThreadLimit     64
     StartServers     3
     MinSpareThreads  75
     MaxSpareThreads  250
     MaxClients       400  # 16 * 25
     ThreadsPerChild  25
     MaxRequestsPerChild   10000
</IfModule>

同分类推荐文章

  1. 等了十年的 Go 链式管道,终于来了:seq 让你像写 Scala 一样写 Go (2026-06-25 18:38:18)
  2. Go 实验特性详解 (2026-06-21 10:05:27)
  3. amd64 微架构级别对 Go 程序性能提升多少? (2026-06-21 09:38:49)

查看更多 后端 文章 →

建议继续学习

  1. Linux如何统计进程的CPU利用率 (累计阅读 16,308)
  2. 我的 RHCA 之路 (累计阅读 14,013)
  3. Linux内存点滴 用户进程内存空间 (累计阅读 13,232)
  4. 给程序员新手的一些建议 (累计阅读 13,090)
  5. Linux 性能监控、测试、优化工具 (累计阅读 13,013)
  6. 关于linux内存free的一些事情 (累计阅读 12,869)
  7. ps - 按进程消耗内存多少排序 (累计阅读 12,690)
  8. Google怎么用linux (累计阅读 12,582)
  9. Linux Used内存到底哪里去了? (累计阅读 11,868)
  10. find命令的一点注意事项 (累计阅读 11,867)