当前位置:七道奇文章资讯网站建设网站编程
日期:2011-09-17 13:32:00  来源:本站整理

PHP拜候MySQL查询超时处理[网站编程]

赞助商链接



  本文“PHP拜候MySQL查询超时处理[网站编程]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:

PHP衔接MySQL主如果利用Mysql供应的 libmysqlclient 的客户端库,同时也延伸出来 mysql 和  mysqli 两套PHP的扩大,相对来说 mysqli 比 mysql 更好,更安定.

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

  1. <?php 
  2. //成立对象 
  3. $mysqli = mysqli_init(); 
  4.  
  5. //设置超时选项 
  6. $mysqli->options(MYSQLI_OPT_CONNECT_TIMEOUT, 5); 
  7.  
  8. //衔接 
  9. $mysqli->real_connect('localhost', 'my_user', 'my_password', 'world'); 
  10.  
  11. //假如超时大概其他衔接失利打印错误信息 
  12. if (mysqli_connect_errno()) { 
  13.     printf("Connect failed: %s/n", mysqli_connect_error()); 
  14.     exit(); 
  15. //成功输出衔接信息 
  16. printf ("Connection: %s/n.", $mysqli->host_info); 
  17.  
  18. $mysqli->close(); 
  19. ?> 

这个是衔接超时,但是有些时刻我们需求查询读写超时,比方说我们一个数据库压力很大,大概衔接很多,那么数据库查询就很迟钝,但是我但愿某些不重要 的数据,比方说文章点击数这种假如查询超时了就不显示,至少可以保证主体页面精确显示,但是查遍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查询超时处理
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .