首页 > 数据库 > MySQL > 正文

mysql设置查询超时方法

2024-07-24 12:38:55
字体:
来源:转载
供稿:网友

文章来介绍了自定义mysql查询超时的时间长度,下面我们来看看详细的设置方法,首先, 在libmysql中,是提供了MYSQL_OPT_READ_TIMEOUT设置项的,并且libmysql中提供了设置相关设置项的API,代码如下:

  1. mysql_options: 
  2.  
  3. int STDCALL 
  4.  
  5. mysql_options(MYSQL *mysql,enum mysql_option option, const void *arg) 
  6.  
  7.  
  8.   DBUG_ENTER("mysql_option"); 
  9.  
  10.   DBUG_PRINT("enter",("option: %d",(int) option)); 
  11.  
  12.   switch (option) { 
  13.  
  14.   case MYSQL_OPT_CONNECT_TIMEOUT: 
  15.  
  16.     mysql->options.connect_timeout= *(uint*) arg; 
  17.  
  18.     break
  19.  
  20.   /** 读超时时间 */ 
  21.  
  22.   case MYSQL_OPT_READ_TIMEOUT: 
  23.  
  24.     mysql->options.read_timeout= *(uint*) arg; 
  25.  
  26.     break
  27.  
  28.   case MYSQL_OPT_WRITE_TIMEOUT: 
  29.  
  30.     mysql->options.write_timeout= *(uint*) arg; 
  31.  
  32.     break
  33.  
  34.   case MYSQL_OPT_COMPRESS: 
  35.  
  36.     mysql->options.compress= 1; 

但是,可惜的是,目前只有mysqli扩展,把mysql_options完全暴露给了PHP,代码如下:

  1. PHP_FUNCTION(mysqli_options) 
  2.  
  3.  
  4.  /** 有省略 */ 
  5.  
  6.      switch (Z_TYPE_PP(mysql_value)) { 
  7.  
  8.         /** 没有任何限制, 直接传递给mysql_options */ 
  9.  
  10.         case IS_STRING
  11.  
  12.             ret = mysql_options(mysql->mysql, mysql_option, Z_STRVAL_PP(mysql_value)); 
  13.  
  14.             break
  15.  
  16.         default
  17.  
  18.             convert_to_long_ex(mysql_value); 
  19.  
  20.             l_value = Z_LVAL_PP(mysql_value); 
  21.  
  22.             ret = mysql_options(mysql->mysql, mysql_option, (char *)&l_value);  //Vevb.com 
  23.  
  24.             break
  25.  
  26.     } 
  27.  
  28.     RETURN_BOOL(!ret); 
  29.  

但是因为Mysqli并没有导出这个常量,所以我们需要通过查看MySQL的代码,得到MYSQL_OPT_READ_TIMEOUT的实际值,然后直接调用mysql_options,代码如下:

  1. enum mysql_option 
  2.  
  3.  
  4.   MYSQL_OPT_CONNECT_TIMEOUT, MYSQL_OPT_COMPRESS, MYSQL_OPT_NAMED_PIPE, 
  5.  
  6.   MYSQL_INIT_COMMAND, MYSQL_READ_DEFAULT_FILE, MYSQL_READ_DEFAULT_GROUP, 
  7.  
  8.   MYSQL_SET_CHARSET_DIR, MYSQL_SET_CHARSET_NAME, MYSQL_OPT_LOCAL_INFILE, 
  9.  
  10.   MYSQL_OPT_PROTOCOL, MYSQL_SHARED_MEMORY_BASE_NAME, MYSQL_OPT_READ_TIMEOUT, 
  11.  
  12.   MYSQL_OPT_WRITE_TIMEOUT, MYSQL_OPT_USE_RESULT, 
  13.  
  14.   MYSQL_OPT_USE_REMOTE_CONNECTION, MYSQL_OPT_USE_EMBEDDED_CONNECTION, 
  15.  
  16.   MYSQL_OPT_GUESS_CONNECTION, MYSQL_SET_CLIENT_IP, MYSQL_SECURE_AUTH, 
  17.  
  18.   MYSQL_REPORT_DATA_TRUNCATION, MYSQL_OPT_RECONNECT, 
  19.  
  20.   MYSQL_OPT_SSL_VERIFY_SERVER_CERT 
  21.  
  22. }; 

可以看到,MYSQL_OPT_READ_TIMEOUT为11,现在,我们就可以设置查询超时了,代码如下:

  1. $mysqli = mysqli_init(); 
  2.  
  3. $mysqli->options(11 /*MYSQL_OPT_READ_TIMEOUT*/, 1); 
  4.  
  5. $mysql->real_connect(***); 

不过, 因为在libmysql中有重试机制(尝试一次, 重试俩次),所以,最终我们设置的超时阈值都会三倍于我们设置的值.

也就是说,如果我们设置了MYSQL_OPT_READ_TIMEOUT为1,最终会在3s以后超时结束,也就是说,我们目前能设置的最短超时时, 就是3秒…

虽说大了点,不过总比没有好, 呵呵

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表