首页 / Mysql / PHP访问MySQL查询超时处理的方法

PHP访问MySQL查询超时处理的方法

 手册里只有这么四个选项跟踪 mysqli 的扩展源代码发现它底层调用的是 libmysqlclient 的 mysql_options:

目前两个客户端扩展库连接超时可以设置选项来操作,比如mysqli:

这个是连接超时,但是有些时候我们需要查询读写超时,比如说我们一个数据库压力很大,或者连接很多,那么数据库查询就很缓慢,但是我希望某些不重要的数据,比如说文章点击数这种如果查询超时了就不显示,至少能够保证主体页面正确显示,但是查遍PHP手册没有发现这个操作选项或者函数。

 

手册里只有这么四个选项

PHP访问MySQL查询超时处理的方法

跟踪 mysqli 的扩展源代码发现它底层调用的是 libmysqlclient 的 mysql_options:

php-5.2.8/ext/mysqli/mysqli_api.c

PHP访问MySQL查询超时处理的方法

并且在mysqli的PHP扩展中就只导出了几个变量:

php-5.2.8/ext/mysqli/mysqli.c

PHP访问MySQL查询超时处理的方法

大概看了一下 libmysqlclient 的代码,发现其实它自带是有读写超时设置的:

mysql-5.1.30/sql-common/client.c

PHP访问MySQL查询超时处理的方法

因为它自己定义了很多操作选项,只是php扩展里没有:

mysql-5.1.30/include/mysql.h

PHP访问MySQL查询超时处理的方法

看看mysql中的读写超时是如何实现的:

mysql-5.1.30/sql-common/client.c

PHP访问MySQL查询超时处理的方法

PHP访问MySQL查询超时处理的方法

读写超时真正操作的地方,超时处理这里重试了两次,还是写死了:

mysql-5.1.30/sql/net_serv.cc

PHP访问MySQL查询超时处理的方法

PHP访问MySQL查询超时处理的方法

现在基本得出了结论:

按照上面查看代码来看,目前PHP针对MySQL查询超时以下限制:

1. 超时设置单位为秒,最少配置1秒

2. 但mysql底层的read会重试两次,所以实际会是 3 秒

 

重试两次 + 自身一次 = 3倍超时时间。

 

那么就是说最少超时时间是3秒,不会低于这个值,对于大部分应用来说可以接受,但是对于小部分应用需要优化。
现在我们来看看如果我们自己要设置超时,我们自己压入 MYSQL_OPT_READ_TIMEOUT 也是可以达到读写超时效果的,写一段代码来测试一下:

查看上面代码的执行结果,验证了上面的观点,第一个查询成功了,第二个查询连接被断开了:

PHP访问MySQL查询超时处理的方法

如果需要修改这个秒级别的超时,比如改成毫秒级别的超时,只能两个地方修改:

 

1.  修改客户端,比如 mysqli query 代码,加入定时器,超时则返回

2.  修改 Mysql 中的vio代码,因为mysql的网络处理底层都是经过vio的操作

MySQL相关的vio代码:

poll 超时:

PHP访问MySQL查询超时处理的方法

setsockopt 超时:

PHP访问MySQL查询超时处理的方法

基本上到这里就基本能够解决PHP在针对MySQL读写查询操作超时的处理了,希望对你有帮助。
heiyeluren的blog

本文来自网络,不代表我是攻城狮立场,转载请注明出处:https://www.54gcs.cn/sql/mysql/644.html

helwo作者

上一篇
下一篇

为您推荐

发表评论

联系我们

联系我们

在线咨询: QQ交谈

邮箱: web@5vo.cn

工作时间:周一至周五,9:00-17:30,节假日休息
关注微信
微信扫一扫关注我们

微信扫一扫关注我们

手机访问
手机扫一扫打开网站

手机扫一扫打开网站

返回顶部
跳至工具栏