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

php中文网
发布: 2016-06-06 20:19:18
原创
1855人浏览过

今天发现网站打开特别慢,然后分析原因,发现是数据库查询花费时间特别长,一个最简单的查询都至少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 更新
测试代码如下:

Dreamlike.art
Dreamlike.art

内置5种模型的AI图像生成器

Dreamlike.art 57
查看详情 Dreamlike.art

立即学习PHP免费学习笔记(深入)”;

$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 更新
测试代码如下:

立即学习PHP免费学习笔记(深入)”;

$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速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号