素材牛VIP会员
php中new PDO()需要几秒钟时间?
 de***oo  分类:ThinkPHP  人气:789  回帖:5  发布于6年前 收藏

今天发现网站打开特别慢,然后分析原因,发现是数据库查询花费时间特别长,一个最简单的查询都至少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大法好啊!!!
最后,真诚的感谢各位同仁的热心帮助,祝各位年终奖翻倍!!!

 标签:thinkphppdophp

讨论这个帖子(5)垃圾回帖将一律封号处理……

Lv1 新人
qi***hu 职业无 6年前#1

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

Lv1 新人
威***军 职业无 6年前#2

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

Lv4 码徒
飞***6 Linux系统工程师 6年前#3

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

Lv6 码匠
谎***y 技术总监 6年前#4

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

Lv4 码徒
青***e Linux系统工程师 6年前#5

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

 文明上网,理性发言!   😉 阿里云幸运券,戳我领取