Ubuntu apache 进程消耗 100% CPU PHP/MySQL 应用程序

Ubuntu apache 进程消耗 100% CPU PHP/MySQL 应用程序

我在 Rackspace 有一台服务器,连接到运行 MySQL 的 Cloud DB 实例。我不是服务器管理员,因此很抱歉没有足够的数据。我很难确定是什么导致我的 apache 服务器在 10 个并发用户的负载下 CPU 占用率达到 100%(我使用 Neustar 设置了负载测试)。

我的mod_status输出:

在此处输入图片描述

我的mpm_prefork.conf

 <IfModule mpm_prefork_module>
    StartServers            2
    MinSpareServers         2
    MaxSpareServers         10
    MaxRequestWorkers       150
    MaxClients              10
    MaxConnectionsPerChild  0
 </IfModule>

我知道我的问题出在代码上,但我不清楚从哪里开始,也不清楚代码中是否有mod_status我不明白的细节。我们使用 PDO 连接数据库,而 Rackspace 让我们使用 DNS,所以我不确定执行反向查找是否会损害 CPU。我还有 2 张来自 New Relic 的屏幕截图,显示了服务器的使用情况。这是一个小型暂存服务器,这就是为什么我只有 1 个 CPU 和 1G 内存 - 以及为什么我只测试了 10 个用户。

在此处输入图片描述

请让我知道我还可以发布什么来帮助诊断问题。

答案1

正确回答这个问题需要几万字(我知道,我已经之前尝试回答过)。但查看您提供的数字确实能提供一些线索。

使用大量 CPU 意味着您可以消除很多潜在问题。LAMP 平台上的高 CPU 使用率通常是一个很好的信号 - 这意味着系统不是花费大量时间等待网络、数据库和磁盘 I/O 的发生。

话虽如此,当并发​​连接数只有 10 个时,平均负载超过 3 是非常糟糕的。响应速度为 2.7/秒是非常糟糕的。而且我怀疑平均响应时间非常非常糟糕。

这太糟糕了,我要做的第一件事就是检查是否配置了任何操作码缓存。如果有,那么你应该检查它的大小是否正确。

仅 1CPU 和 1G 内存

我运行过 LAMP 服务器,每个实例有 120 个并发客户端,内存量如此之大(还有足够的空间用于 VFS 和 DB)。当然,很大程度上取决于你的代码是什么样子的——这当然不是其他人可以在这里给出明智意见的事情。一旦你检查了操作码缓存,你可能想要安装西哈尔滨工业大学并开始调查你的代码出了什么问题。

(顺便说一句,您的 httpd 配置中似乎混合了 2.2 和 2.4 配置指令 - 您可能也想花一些时间清理它们)。

相关内容