php中new PDO()需要几秒钟时间?

徐哈哈
  • 114

今天发现网站打开特别慢,然后分析原因,发现是数据库查询花费时间特别长,一个最简单的查询都至少4秒以上,然后分析最终发现原因是执行new PDO(...) 时间花费4秒以上,请问可能是因为什么原因?

网站用的thinkphp框架,服务器版本:windows serve 2008.
数据库在另外一台服务器上。

另:1.new PDO(localhost...) 不存在该问题
2.new PDO(另外一个windows上运行的数据库) 出现同样问题
3.new PDO(另外一个linux上运行的数据库) 不存在该问题
4.在本地环境中new PDO(同一数据库) 不存在该问题
...

请求大神解惑啊!!!谢谢

2016-01-28 09:32 更新
测试代码如下:

$t1=microtime(true);
$dsn = "mysql:host=59.175.142.**;dbname=iqgame";
$db = new PDO($dsn, '****', '****');s
$t2=microtime(true);
echo $t2-$t1;     // 输出4s多

1.web服务器与数据库服务器均在外网,连接数据库使用IP连接
2.这个问题是突然之间出现的,以前没有这么严重的连接时间
3.感谢大家伙的热心帮助~

2016-01-28 10:11 再次更新:
感谢 @LakeChan 的提醒,我试着将web服务器中的防火墙关闭,则瞬间解决问题!!!
然后我也不知道该怎么配置防火墙才能屏蔽该问题,只能一条一条规则的尝试,然后,待我重新打开防火墙后发现问题居然没有再出现了!!!
这种心情,感觉被狗[和谐]日了一样!!!

总结,虽然不知道究竟发生了什么!但是真心觉得还是Linux大法好啊!!!
最后,真诚的感谢各位同仁的热心帮助,祝各位年终奖翻倍!!!

回复
阅读 4.1k
5 个回答

1.使用IP而不是域名,使用域名会让PDO在连接之前进行一次不必要的dns lookup,当DNS缓存过于巨大的时候,这个问题可能会更严重。(即使是运行在本机,使用 127.0.0.1 而不是 localhost)
2.如果连接到内网的其他服务器,内网的网络节点是否工作正常?是否会有防火墙处理连接过慢的问题?

web 服务器连数据库服务器是局域网还是公网?

看不到代码,难说。与数据库是IP连的还是域名连的也有关系

首先看看是不是因为IPV6的原因导致连接慢,其次看看Mysql配置是否合理。PHP不会出现连接慢的问题,问题肯定在mysql上

楼主,php的pdo是C写的扩展,效率是极高的,基本一个连接是毫秒级,所以不用怀疑扩展本身。
1、先看看是否代码问题,单独写个demo用pdo连接下看,耗时多少
2、telnet一下web机跟sql机的耗时看看,是否网络问题(最常见)

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
你知道吗?

宣传栏