PHP访问MySQL查询超时处理

转载 2015年07月08日 20:15:14

PHP连接MySQL主要是使用Mysql提供的 libmysqlclient 的客户端库,同时也延伸出来 mysql 和  mysqli 两套PHP的扩展,相对来说 mysqli 比 mysql 更好,更稳定。

 

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

 

<?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: %s/n", mysqli_connect_error());
    exit();
}
//成功输出连接信息
printf ("Connection: %s/n.", $mysqli->host_info);

$mysqli->close();
?>

 

这个是连接超时,但是有些时候我们需要查询读写超时,比如说我们一个数据库压力很大,或者连接很多,那么数据库查询就很缓慢,但是我希望某些不重要的数据,比如说文章点击数这种如果查询超时了就不显示,至少能够保证主体页面正确显示,但是查遍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 也是可以达到读写超时效果的,写一段代码来测试一下:

<?php
//自己定义读写超时常量
if (!defined('MYSQL_OPT_READ_TIMEOUT')) {
        define('MYSQL_OPT_READ_TIMEOUT',  11);
}
if (!defined('MYSQL_OPT_WRITE_TIMEOUT')) {
        define('MYSQL_OPT_WRITE_TIMEOUT', 12);
}

//设置超时
$mysqli = mysqli_init();
$mysqli->options(MYSQL_OPT_READ_TIMEOUT, 3);
$mysqli->options(MYSQL_OPT_WRITE_TIMEOUT, 1);

//连接数据库
$mysqli->real_connect("localhost", "root", "root", "test");
if (mysqli_connect_errno()) {
   printf("Connect failed: %s/n", mysqli_connect_error());
   exit();
}

//执行查询 sleep 1秒不超时
printf("Host information: %s/n", $mysqli->host_info);
if (!($res=$mysqli->query('select sleep(1)'))) {
    echo "query1 error: ". $mysqli->error ."/n";
} else {
    echo "Query1: query success/n";
}

//执行查询 sleep 9秒会超时
if (!($res=$mysqli->query('select sleep(9)'))) {
    echo "query2 error: ". $mysqli->error ."/n";
} else {
    echo "Query2: query success/n";
}

$mysqli->close();
echo "close mysql connection/n";
?>

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

 

 

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

 

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

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

MySQL相关的vio代码:

poll 超时:

setsockopt 超时:

 

 

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

【原创】PHP访问MySQL查询超时处理

本文讲解了PHP除了连接MySQL超时操作之后针对MySQL读写超时的处理
  • heiyeshuwu
  • heiyeshuwu
  • 2010年09月08日 01:18
  • 17668

php使用mysql-timeout包,解决sql语句查询超时问题

先放地址:https://github.com/wwaayyaa/mysql-timeout php遇到慢sql的时候,一般就是调整php的最大执行时间,mysql的执行时间等配置。 但是...
  • wwaayyaaa
  • wwaayyaaa
  • 2016年09月26日 17:01
  • 881

关于php pdo连接mysql,查询超时问题

很少写博客,格式不好,见谅。 首先问题是这样发现的, 我在php项目使用到了 workerman,这是一个 常驻内存的cli模式下的socket开发包。(非常给力!) 然后有时候task进程或无故卡死...
  • wwaayyaaa
  • wwaayyaaa
  • 2016年09月23日 16:19
  • 2351

几种常见的PHP超时处理方法

你在使用PHP时会不会遇到下面几种问题呢? 1. 异步获取数据如果某个后端数据源获取不成功则跳过,不影响整个页面展现 2. 为了保证Web服务器不会因为当个页面处理性能差而导致无法访问其他...
  • for023
  • for023
  • 2014年06月11日 17:25
  • 3427

php----处理从mysql查询返回的数据

使用php的mysql,向mysql查询,返回的是一个资源,有4个函数可以进行处理。 1.mysql_fetch_row() 2.mysql_fetch_assoc() 3.mysql_fetc...
  • huyishero
  • huyishero
  • 2016年12月03日 21:00
  • 1440

MySQL查询超时问题的解决

MySQL查询超时问题是什么原因呢?应该如何解决呢? 下面就为您详细介绍MySQL查询超时问题的解决方法,希望可以帮助到您。 mysql>show variables like '%tim...
  • milife2012
  • milife2012
  • 2015年01月23日 01:50
  • 3601

查看mysql连接情况,以及连接超时时间设置

查看连接: show processlist;   只展示100个连接 show full processlist;    展示所有连接 查看超时时间: show variables like ...
  • csCrazybing
  • csCrazybing
  • 2016年11月23日 12:36
  • 5764

mysql 客户端查询超时时间的控制

MYSQL_OPT_CONNECT_TIMEOUT  MYSQL_OPT_READ_TIMEOUT  MYSQL_OPT_WRITE_TIMEOUT  如果这3个不设置,如果拔掉网线后重...
  • xiuzhentianting
  • xiuzhentianting
  • 2017年08月14日 13:25
  • 441

php curl 超时处理

php curl处理请求超时 背景:写了一个api管理的工具,增加了api请求的的工具,某些接口请求时间比较长,某些接口时间必须要短,希望超过超时时间的请求返回其它的状态码,要跟失败或者curl失败区...
  • jin123456bat
  • jin123456bat
  • 2017年05月05日 15:08
  • 2637

mysql sql php 参数化查询

参数化查询(Parameterized Query 或 Parameterized Statement)是指在设计与数据库连结并访问数据时,在需要填入数值或数据的地方,使用参数 (Parameter)...
  • jielione
  • jielione
  • 2012年11月27日 17:43
  • 4753
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:PHP访问MySQL查询超时处理
举报原因:
原因补充:

(最多只允许输入30个字)