windows – 从PHP连接MySQL非常慢
我刚刚安装了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",""); mysql_select_db("mysql",$con); $result = mysql_query('SELECT host,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) 编辑:在计时之后,事实证明这是连接功能需要这么长时间: $time = microtime(true); $con = mysql_connect("localhost",$con); $con_time = microtime(true); $result = mysql_query('SELECT host,password FROM user;'); $sel_time = microtime(true); printf("Connect time: %fnQuery time: %fn",$con_time-$time,$sel_time-$con_time); 输出: Connect time: 1.006148 Query time: 0.000247 什么可以导致PHP花费很多时间连接到数据库? CLI客户端,HeidiSQL和MySQL工作台即时连接 可能是你的mysql尝试连接时运行rev-dns查询?尝试添加到my.cnf,部分mysqld: skip-name-resolve.(编辑:承德站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- Windows 10防火墙阻止Visual Studio
- 12月份GitHub上最热门的Web开源项目
- active-directory – 将2012 R2域控制器添加到2008 R2功能级
- windows-server-2008 – 从属证书颁发机构的目的
- windows-server-2008 – 为什么Windows 2K3 / 2K8域控制器上
- Windows 10 5月更新:这10个新功能你不能错过
- 都说Linux是吃内存大户,可你知道具体是哪些进程吃掉了吗?
- 从一幅画看浏览器的不同
- windows-server-2008 – 为SQL Server操作系统配置6个磁盘r
- windows-server-2003 – 在小型企业环境中摆脱服务器