有一个严重的问题。我有运行 Apache 的虚拟服务器和两个有很多访问者的 Web 项目(大约每秒 5 次点击)。我的服务器开始自行关闭。在错误日志中我发现了这个问题
[error] server reached MaxClients setting, consider raising the MaxClients setting
[notice] caught SIGTERM, shutting down
所以我寻找解决方案来提高这些数字。我发现这个数字在 apache 配置中分为两个部分。和
/usr/sbin/httpd -l
Compiled in modules:
core.c
prefork.c
http_core.c
mod_so.c
我发现我的服务器正在使用 prefork。所以我再次寻找合适的值并尝试了这些
<IfModule prefork.c>
StartServers 8
MinSpareServers 5
MaxSpareServers 20
ServerLimit 1024
MaxClients 1024
MaxRequestsPerChild 4000
</IfModule>
但即使使用这些值,服务器仍会关闭。任何人都可以指导我去哪里看,读什么,或者为服务器的正常稳定运行设置什么?伙计们,我将不胜感激。
服务器运行Linux CentOS 5.4
谢谢贝尼
由于您的服务器正在运行 prefork 模式,这意味着每个连接都有自己的进程 - 所以首先检查系统上是否有 1024 个左右的 httpd 进程正在运行。
为了更好地处理您的服务器正在做什么,您可能需要启用服务器状态页面。
然后,这将允许您查看与服务器的连接状态,并尝试找出导致所有连接被消耗的原因。
我的怀疑是某种流氓代理或重写语句的可能性,这会导致服务器在自身内部不断循环其连接,直到所有连接都被消耗掉。
也许您的服务器启用了 KeepAlive 功能并且 KeepAliveTimeOut 的价值非常高?
这可能会产生一堆等待关闭的非活动连接,最终导致服务器崩溃。
检查您的 apache 配置和/或虚拟主机定义。
米
在再次增加数字之前,您可以做一些事情来减少 Apache 产生的进程数量。
启用 keepalive 并为其设置一个极低的超时时间:
来自同一客户端的所有请求都将通过与服务器的单个 TCP 连接进行处理。较低的 KeepAliveTimeout 值意味着 Apache 将快速终止 KeepAlive 连接,因此只要客户端不留下超过 5 秒的通信暂停,客户端就可以仅使用单个连接来加载整个页面。
此外,将每个子进程的最大请求数降低到 1000 个左右。Apache 进程的内存使用量通常会随着每个请求而增长,因此降低最大请求数最终会降低给定数量的 httpd 进程的总体内存使用量。
最后,如前所述,您应该在服务器最繁忙的时间使用 TOP 或 ps 命令监视服务器。找出有多少 apache 进程正在生成以及每个进程消耗了多少内存。然后,您可以根据服务器可用内存和每个进程的内存使用情况计算适当的最大客户端数。
如果您在这些调整后仍然看到问题,您可能需要考虑摆脱 Apache 的默认 prefork 模块并改用 worker mpm 模块。这将需要使用 fastcgi 或类似的东西来处理 php 请求;最终,尽管这本身就是一个好主意。
咳嗽nginx咳嗽;)