[PHP] PDO对象与mysql的连接超时
在php中每一个new的pdo对象,都会去连接mysql,都会创建一条tcp连接.当pdo对象赋予的变量是一个的时候,那么他只会保持一个tcp连接,没有被引用的对象连接会直接断掉.如果不对这个对象进行任何操作,不传输任何数据,这条连接会在10秒后被mysql服务断掉.
如果使用了长连接参数,那么不管循环执行几次new pdo,只会有一个tcp连接
关于超时现象,网上的资料大部分说受两个参数interactive_timeout和wait_timeout影响,但是经过我测试,修改了这两个参数,如果10秒没有任何操作,连接仍然会被mysql断掉,不管是使不使用长连接参数.
如果每隔一秒传输数据,那么这条连接就会一直存在,状态一直是established.如果是会出现两次执行时间较长,连接会被mysql断掉
对于需要长期执行的数据库操作脚本,比较稳妥的方式是每隔8秒左右重新new pdo对象,或者每隔循环一定次数确保在10秒内重新new pdo对象
测试过程如下:
开一个终端,不停的查看当前的连接情况
while true;do clear;date;netstat -altupn|grep 3306;sleep 1;done
另一个终端执行php脚本,可以暂时把长连接参数去掉,可以看到有很多tcp连接,状态是time_wait,是客户端主动关闭的.
而被mysql断掉的连接是close_wait状态,也就是被关闭一方,mysql服务里的连接是fin_wait2
<?php //$option=array(pdo::attr_persistent => true); for($i=0;$i<10;$i++){ $pdo=new pdo("mysql:host=127.0.0.1;dbname=my_test","root","xxx",$option); var_dump($pdo); } while(1){ sleep(5); $pdo->query("set names utf8"); sleep(11); }
上一篇: 生芝麻什么时候吃最好,吃生芝麻最佳的时间
下一篇: 原生JavaScript遮罩
推荐阅读
-
PHP连接MySQL数据库的三种方式实例分析【mysql、mysqli、pdo】
-
php使用mysqli和pdo扩展,测试对比连接mysql数据库的效率完整示例
-
PHP封装mysqli基于面向对象的mysql数据库操作类与用法示例
-
php与mysql建立连接并执行SQL语句的代码
-
[PHP] PDO对象与mysql的连接超时
-
PHP API中,MYSQL与MYSQLI的持久连接区别
-
深入探讨:PHP使用数据库永久连接方式操作MySQL的是与非
-
[日常] PHP与Mysql测试kill慢查询并检验PDO的错误模式
-
PHP连接MySQL数据库的三种方式实例分析【mysql、mysqli、pdo】
-
php pdo对象使用详解: 连接数据库与exec方法