当前位置:  数据库>mysql

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

    来源: 互联网  发布时间:2014-09-06

    本文导语:  目前两个客户端扩展库连接超时可以设置选项来操作,比如mysqli: 代码如下: 这个是连接超时,但是有些时候我们需要查询读写超时,比如说我们一个数据库压力很大,或者连接很多,那么数据库查询就很缓慢,但是我希望...

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



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

 

手册里只有这么四个选项

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

php-5.2.8/ext/mysqli/mysqli_api.c

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

php-5.2.8/ext/mysqli/mysqli.c

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

mysql-5.1.30/sql-common/client.c

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

mysql-5.1.30/include/mysql.h

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

mysql-5.1.30/sql-common/client.c

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

mysql-5.1.30/sql/net_serv.cc

现在基本得出了结论:

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

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

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

 

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

 

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

代码如下:



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

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

 

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

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

MySQL相关的vio代码:

poll 超时:

setsockopt 超时:

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


    
 
 

您可能感兴趣的文章:

  • php 30秒超时限制怎么解决
  • PHP Session会话超时时间设置方法教程
  • 一个严格的PHP Session会话超时时间设置方法
  • PHP file_get_contents超时处理的设置方法
  • PHP严重致命错误处理:php Fatal error: Cannot redeclare class or function
  • PHP图像处理库 ImageWorkshop
  • PHP图像处理库 Imagine
  • php 下载文件名带空格怎么处理
  • PHP支付处理库 Omnipay
  • PHP的Zip压缩包处理类 TbsZip
  • PHP图像处理模块 MagickWand
  • PHP图像处理库 Zebra_Image
  • windows下配置apache+php+mysql时出现问题的处理方法
  • PHP配置文件处理类代码
  • nginx:413 Request Entity Too Large的处理办法--修改 PHP上传文件大小
  • php事务处理实例详解
  • php异常处理使用示例
  • PHP开发框架kohana中处理ajax请求的例子
  • php5.2 Json不能正确处理中文、GB编码的解决方法
  • PHP中模拟处理HTTP PUT请求的例子
  • PHP按行读取、处理较大CSV文件的代码实例
  • php判断闰年的三种方法(闰年计算方法) iis7站长之家
  • PHP按行读取、处理较大CSV文件的例子
  • php中json_encode处理gbk与gb2312中文乱码问题的解决方法
  • PHP处理SQL脚本文件导入到MySQL的代码实例
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • php5中当浏览器禁用cookie时保持会话session的方法
  • 判断php数组维度(php数组长度)的方法
  • PHP编程语言介绍及安装测试方法
  • 图解找出PHP配置文件php.ini的路径的方法
  • php类声明和php类使用方法示例分享
  • windows下PHP_intl.dll正确配置方法(apache2.2+php5.3.5)
  • 查找php配置文件php.ini所在路径的二种方法
  • php定义数组和使用示例(php数组的定义方法)
  • PHP质数计算三种方法 php求100以内的质数
  • PHP错误Parse error: syntax error, unexpected end of file in test.php on line 12解决方法
  • php反射机制获取php类的所有方法
  • iis加载不到php.ini的解决方法
  • php跨域cookie共享使用方法
  • 两种设置php载入页面时编码的方法
  • PHP快速排序小例子 php快速排序实现方法
  • PHP exif扩展方法开启详解
  • php出现Class 'XsltProcessor' not found问题的解决方法
  • windows下开启PHP GD库的方法
  • php判断闰年的三种方法(闰年计算方法)
  • php向js函数传参的几种方法
  • php检测iis环境是否支持htaccess的方法
  • 修改配置真正解决php文件上传大小限制问题(nginx+php)
  • IIS7配置PHP图解(IIS7+PHP_5.2.17/PHP_5.3.5)
  • PHP 5.4.19 和 PHP 5.5.3 发布及下载地址
  • php输入流php://input使用示例(php发送图片流到服务器)
  • 修改配置真正解决php文件上传大小限制问题(apache+php)
  • PHP转换器 HipHop for PHP
  • PHP去除html标签,php标记及css样式代码参考
  • PHP 框架 Pop php
  • PHP 'ext/soap/php_xml.c'不完整修复存在多个任意文件泄露漏洞
  • PHP的JavaScript框架 PHP.JS


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3