php连接mysql 慢_windows – 从PHP连接MySQL非常慢

博主在使用XAMPP的PHPMyAdmin时遇到页面加载慢的问题,经过测试发现问题可能在于PHP连接MySQL的过程,而非PHP本身或MySQL查询。使用PDO和mysql_connect进行连接和查询,发现连接时间显著较长,而查询时间较短。CLI客户端和其他工具如HeidiSQL和MySQL Workbench则能快速连接。问题聚焦于PHP连接数据库的效率低下,寻求解决方案。
摘要由CSDN通过智能技术生成

我刚刚安装了XAMPP.第一次打开

PHPMyAdmin时,我发现它非常慢.在localhost上打开每个页面几乎需要5秒钟才没有意义.我做了一个小测试案例,将责任从PHPMyAdmin中移除:

$con = new PDO("mysql:host=localhost;dbname=mysql", "root", "");

$statement = $con->query('SELECT host,user,password FROM user;');

$users = $statement->fetchAll(PDO::FETCH_ASSOC);

上面的脚本只需要大约3秒就可以运行(尽管我第一次运行时加载的时间接近8秒.)

然后检查是否是PDO的错误我尝试使用mysql_connect:

$con = mysql_connect("localhost", "root", "");

mysql_select_db("mysql", $con);

$result = mysql_query('SELECT host,user,password FROM user;');

完成需要很长时间.

起初我认为这是PHP的错误,但PHP代码和静态文件比单击刷新更快.我通过运行这个小脚本来测试PHP:

header("Content-Type: text/plain");

for($i = 0; $i < 5000; $i++)

{

echo sha1(rand()) . "\n";

}

5000 sha1计算和页面仍然显示比我刷新窗口更快.

然后我认为这是MySQL的错.但同样,没有经过太多测试来弄清楚MySQL的运行速度比我需要的要快.使用MySQL CLI客户端,用户选择查询甚至不需要花费可测量的时间 – 这是在我甚至让返回键启动之前完成的.

问题必须是PHP与MySQL的连接 – 这是我能够推断出来的.我可以找到很多关于PHP的速度很慢或者MySQL很慢的东西,但是没有关于PHP MySQL的速度非常慢.

感谢任何能帮我解决这个问题的人!

我正在使用XAMPP 1.8.0 for win32(Download link)

PHP版本:5.4.4

MySQL版本:14.14

编辑:在计时之后,事实证明这是连接功能需要这么长时间:

$time = microtime(true);

$con = mysql_connect("localhost", "root", "");

mysql_select_db("mysql", $con);

$con_time = microtime(true);

$result = mysql_query('SELECT host,user,password FROM user;');

$sel_time = microtime(true);

printf("Connect time: %f\nQuery time: %f\n",

$con_time-$time,

$sel_time-$con_time);

输出:

Connect time: 1.006148

Query time: 0.000247

什么可以导致PHP花费很多时间连接到数据库? CLI客户端,HeidiSQL和MySQL工作台即时连接

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值