• 模拟并发访问
ab -n 100000 -c 1000 -k http://weibo.cnsuning.com/index.php
  • 检测 HTTPD 连接数:
watch -n 1 -d “pgrep httpd|wc -l”
  • 确定工作模式 prefork / worker
httpd -l
  • 并发参数设置

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 访问却很慢的主要原因。

  • 其它参数设置

    • ServerTokens Prod – 隐藏服务器版本信息,只显示 apache
    • ServerSignature Off
    • HostnameLookups Off
    • Timeout 5 – 请求超时时间
    • KeepAlive On
    • KeepAliveTimeout 5
    • MaxKeepAliveRequests 100
  • 关闭不需要的模块

注释掉加载该模块,及相关配置项

转载请注明: 转载自Ryan 是菜鸟 | LNMP 技术栈笔记

如果觉得本篇文章对您十分有益,何不 打赏一下

谢谢打赏

本文链接地址: 优化 Apache,提高并发

知识共享许可协议 本作品采用知识共享署名-非商业性使用 4.0 国际许可协议进行许可