在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);
}

最新文章

  1. qt越来越好了
  2. 解决oracle服务器重启之后连接报错的问题
  3. HTML~From
  4. thrift编译安装
  5. 黄页js-sdk开发总结分享
  6. 160826、浏览器渲染页面过程描述,DOM编程技巧以及重排和重绘
  7. Codeforces Gym 100231F Solitaire 折半搜索
  8. Eclipse反编译工具Jad及插件
  9. JqGrid实现自定义查询
  10. 最新的手机/移动设备jQuery插件
  11. [Django] html 前端页面jQuery、图片等路径加载问题
  12. Hongwei Xi
  13. github同一账户+多个库
  14. ng工程升级cli版本
  15. javascript常用积累
  16. sp_executesql 或者 EXECUTE 执行动态sql的权限问题
  17. html5解决ajax破坏浏览器机制
  18. js中解析json时候的eval和$.parseJSON()的区别以及JSON.stringify()
  19. https nginx配置
  20. Java--数组转成list,list转数组

热门文章

  1. Windows下Linux虚拟机的配置以及Win10 linux子系统开启
  2. 初识Kotlin之函数
  3. How to recover a skipped tablespace after an incomplete recovery? (Doc ID 1561645.1)
  4. Python 定时任务的实现方式
  5. go设计模式--单例singleton
  6. React 创建一个自动跟新时间的组件
  7. Ubuntu 18.04 安装 python 的 redis 库
  8. RabbitMQ学习笔记(五、RabbitMQ集群)
  9. 201871010135 张玉晶 《面向对象程序设计(java)》 第一周学习总结
  10. html和css常见问题解答