欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

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

程序员文章站 2022-05-13 08:54:02
...
今天发现网站打开特别慢,然后分析原因,发现是数据库查询花费时间特别长,一个最简单的查询都至少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秒以上,然后分析最终发现原因是执行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大法好啊!!!
最后,真诚的感谢各位同仁的热心帮助,祝各位年终奖翻倍!!!

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

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

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

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

可能是mysql反向解析的问题,可以对比一下windows和linux服务器的myslq的配置文件,看下是否有:
skip-name-resolve

另外,mysql日志应该也会有相应的记录。

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

相关标签: php thinkphp pdo