gpt4 book ai didi

mysql - httpd - CPU 使用率 100% - Mysql 服务器远程位置

转载 作者:可可西里 更新时间:2023-11-01 06:52:25 25 4
gpt4 key购买 nike

数据库一个在本地,另一个在远程服务器位置。框架-cakePHPMysql:5.1.71 - “远程位置”PHP 版本 5.5.14

现在使用本地mysql数据库,用TOP命令查看httpd请求CPU占用正常。

然而,当我使用远程服务器数据库时。访问同一页面时,CPU 使用率高达 70% 或有时为 100%。

以下是php.ini和httpd.conf文件的几个主要设置

php.ini

memory_limit = 128M
max_input_time = 60
post_max_size = 8M

httpd.conf

<IfModule prefork.c>
StartServers 8
MinSpareServers 5
MaxSpareServers 20
ServerLimit 256
MaxClients 256
MaxRequestsPerChild 4000
</IfModule>

<IfModule worker.c>
StartServers 4
MaxClients 300
MinSpareThreads 25
MaxSpareThreads 75
ThreadsPerChild 25
MaxRequestsPerChild 0
</IfModule>

KeepAlive Off
MaxKeepAliveRequests 100
KeepAliveTimeout 15

在这种情况下,httpd 的 CPU 使用率高的原因可能是什么。

我们将不胜感激。

谢谢苏迪尔

最佳答案

我曾经有两个像这样固定的 mysql 服务器。我会有一些脚本来做一些事情。有人会告诉我连接操作是什么样的(服务器上的并发 session 连接)并记录下来。接下来将检查服务使用情况,如果阈值达到 70%,我将开始终止连接并给自己发送一些电子邮件以查看发生了什么。

事实证明,在您正常使用期间,当您希望看到人们浏览您的网站时,却使我的服务器出现故障)。

除了终止 session 之外,我还做了一些事情来缓解这种情况(这并不酷)。是规范我的数据库,重构被大量使用的表。然后我会修复并重建索引。

我还意识到某些事情是无法配置的。我们制造冗余。

我必须镜像我的 MySQL 服务器,然后根据请求参数路由用户。

最终我意识到我需要一些更好的负载平衡并最终得到了 4 个 MySQL 服务器和一个负载平衡器来缓解和引导流量。

所以你的方法是在查询级别,看看你能在那里做什么,然后你的数据库/表重构和重新索引。

接下来创建并发连接谋杀脚本并定位不活跃的用户并将他们重定向到某个地方或者只是剪辑他们并为您网站上的重量级人物让路。

随着时间的推移,我做了很多事情,但这就是今天一切的开始。

希望这对您有所帮助,或者至少让您思考一种方法

关于mysql - httpd - CPU 使用率 100% - Mysql 服务器远程位置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24864714/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com