Mysql必读PHP访问MySQL查询超时处理的方法
《Mysql必读PHP访问MySQL查询超时处理的方法》要点: 代码如下: <?php //创建对象 $mysqli = mysqli_init(); //设置超时选项 $mysqli->options(MYSQLI_OPT_CONNECT_TIMEOUT,5); //连接 $mysqli->real_connect('localhost','my_user','my_password','world'); //如果超时或者其他连接失败打印错误信息 if (mysqli_connect_errno()) { printf("Connect failed: %sn",mysqli_connect_error()); exit(); } //成功输出连接信息 printf ("Connection: %sn.",$mysqli->host_info); $mysqli->close(); ?> 这个是连接超时,但是有些时候我们需要查询读写超时,比如说我们一个数据库压力很大,或者连接很多,那么数据库查询就很缓慢,但是我希望某些不重要的数据,比如说文章点击数这种如果查询超时了就不显示,至少能够保证主体页面正确显示,但是查遍PHP手册没有发现这个操作选项或者函数. ?MYSQL教程 手册里只有这么四个选项MYSQL教程 MYSQL教程跟踪 mysqli 的扩展源代码发现它底层调用的是 libmysqlclient 的 mysql_options:MYSQL教程 php-5.2.8/ext/mysqli/mysqli_api.cMYSQL教程 MYSQL教程并且在mysqli的PHP扩展中就只导出了几个变量:MYSQL教程 php-5.2.8/ext/mysqli/mysqli.cMYSQL教程 MYSQL教程大概看了一下 libmysqlclient 的代码,发现其实它自带是有读写超时设置的:MYSQL教程 mysql-5.1.30/sql-common/client.cMYSQL教程 MYSQL教程因为它自己定义了很多操作选项,只是php扩展里没有:MYSQL教程 mysql-5.1.30/include/mysql.hMYSQL教程 MYSQL教程看看mysql中的读写超时是如何实现的:MYSQL教程 mysql-5.1.30/sql-common/client.cMYSQL教程 MYSQL教程 MYSQL教程读写超时真正操作的地方,超时处理这里重试了两次,还是写死了:MYSQL教程 mysql-5.1.30/sql/net_serv.ccMYSQL教程 MYSQL教程 MYSQL教程 现在基本得出了结论:MYSQL教程
按照上面查看代码来看,目前PHP针对MySQL查询超时以下限制:MYSQL教程 1. 超时设置单位为秒,最少配置1秒MYSQL教程 2. 但mysql底层的read会重试两次,所以实际会是 3 秒MYSQL教程 ?MYSQL教程 重试两次 + 自身一次 = 3倍超时时间.MYSQL教程 ?MYSQL教程 那么就是说最少超时时间是3秒,不会低于这个值,对于大部分应用来说可以接受,但是对于小部分应用需要优化. 查看上面代码的执行结果,验证了上面的观点,第一个查询成功了,第二个查询连接被断开了:MYSQL教程 MYSQL教程 如果需要修改这个秒级别的超时,比如改成毫秒级别的超时,只能两个地方修改:MYSQL教程 ?MYSQL教程 1.? 修改客户端,比如 mysqli 的 query 代码,加入定时器,超时则返回MYSQL教程 2.? 修改 Mysql 中的vio代码,因为mysql的网络处理底层都是经过vio的操作MYSQL教程 MySQL相关的vio代码:MYSQL教程 poll 超时:MYSQL教程 MYSQL教程 setsockopt 超时:MYSQL教程 MYSQL教程 基本上到这里就基本能够解决PHP在针对MySQL读写查询操作超时的处理了,希望对你有帮助. 欢迎参与《Mysql必读PHP访问MySQL查询超时处理的方法》讨论,分享您的想法,编程之家 52php.cn为您提供专业教程。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |