首页 > 其他分享 >wait_timeout and interactive_timeout 参数

wait_timeout and interactive_timeout 参数

时间:2023-06-08 15:24:09浏览次数:45  
标签:timeout session 交互式 interactive 连接 wait

wait_timeout and interactive_timeout 参数

  • 非交互模式连接:通常情况下,应用到RDS实例会采用非交互模式,具体采用哪个模式需要查看应用的连接方式配置,比如PHP通过传递MYSQL_CLIENT_INTERACTIVE常量给mysql_connect()函数即可开启连接的交互模式。wait_timeout参数控制非交互模式连接的超时时间(单位秒,默认值为24小时即86400秒),当非交互式连接空闲时间超过wait_timeout指定的时间后,RDS实例会主动关闭连接。
  • 对于交互模式连接:通过 mysql 客户端 与 mysql server 建立的连接是交互式连接,interactive_timeout参数控制交互模式连接的超时时间(单位秒,默认值为2小时即7200秒),当交互式连接空闲时间超过interactive_timeout指定的时间后,RDS实例会主动关闭连接。
  • wait_timeout和interactive_timeout这两个参数的修改,修改前已经存在的会话保持修改前的设置,修改后新创建的会话使用新的参数设置。

wait_timeout指的是“连接完成后,使用过程中”的等待时间

参数 作用
wait_timeout 非交互式连接建立完成后,使用过程中的等待时间(单位:秒)
interactive_timeout 交互式连接建立完成后,使用过程中的等待时间(单位:秒)

MySQL 8.0.26

client A client B client C
T1 mysql -h -P -u -p
set global wait_timeout = 10;
set global interactive_timeout = 20;
select @@global.wait_timeout, @@global.interactive_timeout;
result (10, 20)
T2 mysql -h -P -u -p
select @@session.wait_timeout, @@session.interactive_timeout;
result (20, 20)
db = pymysql.connect()
cursor = db.cursor()
cursor.execute("select @@session.wait_timeout, @@session.interactive_timeout;")
result (10,20 )
T3 set @@session.wait_timeout = 10;
select @@session.wait_timeout, @@session.interactive_timeout;
result (10, 20)
T4 wait 15s time.sleep(15)
T5 select @@session.wait_timeout, @@session.interactive_timeout;
(ERROR 4031 (HY000): The client was disconnected by the server because of inactivity. See wait_timeout and interactive_timeout for configuring this behavior.)
result(20,20)
cursor.execute("select @@session.wait_timeout, @@session.interactive_timeout;")
pymysql.err.OperationalError: (2013, 'Lost connection to MySQL server during query')
T6 set @@session.wait_timeout = 20;
set @@session.interactive_timeout = 10;
select @@session.wait_timeout, @@session.interactive_timeout;
result (20, 10)
cursor.execute("set @@session.wait_timeout = 20;")
cursor.execute("set @@session.interactive_timeout = 10;")
�cursor.execute("select @@session.wait_timeout, @@session.interactive_timeout;")
result(20, 10)
T7 wait 15s time.sleep(15)
T8 select @@session.wait_timeout, @@session.interactive_timeout;
(Query OK)
result(20,10)
�cursor.execute("select @@session.wait_timeout, @@session.interactive_timeout;")
(Query OK)
result(20,10)

client A 在 T1 时刻将全局变量 wait_timeout 和 interactive_timeout 分别设置为 10s 和 20s。

client B 在 T2 时刻通过 mysql 客户端与 mysql server 建立连接(交互式连接),该连接中会话变量 wait_timeout 和 interactive_timeout 分别为 20s 和 20s, 因此可知交互式连接的会话变量 wait_timeout 和 interactive_timeout 都继承自全局变量 interactive_timeout 的值,接着 client B 在 T3 时刻,将会话变量 wait_timeout 设置为 10s,之后等待 15s,再查看会话变量 wait_timeout、interactive_timeout 时,发现连接已经断开,这说明交互式连接的连接闲置阈值由会话变量 wait_timeout 控制,client B 在 T6 时刻,将会话变量 wait_timeout 和 interactive_timeout 的值分别设置为 20s 和 10s,之后同样等待 15s,在 T8 时刻,再查看会话变量 wait_timeout、interactive_timeout 时,发现连接依旧未断开,直到 20s 后才断开连接,因此可知交互式连接的连接闲置阈值由会话变量 wait_timeout 控制,与会话变量 interactive_timeout 无关。

client C 在 T2 时刻通过 pymysql 与 mysql server 建立连接(非交互式连接),该连接中会话变量 wait_timeout 和 interactive_timeout 分别为 10s 和 20s, 因此可知非交互式连接的会话变量 wait_timeout 和 interactive_timeout 分别继承全局变量 wait_timeout 和 interactive_timeout 的值,接着 client C 在 T4 时刻等待 15s,再查看会话变量 wait_timeout、interactive_timeout 时,发现连接已经断开,这说明非交互式连接的连接闲置阈值由会话变量 wait_timeout 控制,client C 在 T6 时刻将会话变量 wait_timeout 和 interactive_timeout 的值分别设置为 20s 和 10s。之后等待 15s,在 T8 时刻,再查看会话变量 wait_timeout、interactive_timeout 时,发现连接依旧未断开,直到 20s 后才断开连接,因此可知非交互式连接的连接闲置阈值由会话变量 wait_timeout 控制,与会话变量 interactive_timeout 无关。

总结

  1. 交互式连接的会话变量 wait_timeout 和 interactive_timeout 都继承自全局变量 interactive_timeout 的值
  2. 非交互式连接的会话变量 wait_timeout 和 interactive_timeout 分别继承自全局变量 wait_timeout 和 interactive_timeout
  3. 无论是交互式连接还是非交互式连接,连接闲置阈值都由会话变量 wait_timeout 控制,与会话变量 interactive_timeout 无关。

FAQ

为什么叫交互式和非交互式连接?通俗解释不知道?

wait_timeout 和 interactive_timeout 参数应设置为多大?

  • 参数 wait_timeout 和 interactive_timeout 应尽量设置成相同
  • 设置为多大取决于业务,如果你面对的是成熟的开发(比如公司内部团队),可以设置小些,分钟级别就行。

参考资料

MySQL会话闲置时间控制
如何处理RDS MySQL连接数满情况

标签:timeout,session,交互式,interactive,连接,wait
From: https://www.cnblogs.com/ymsu/p/17466558.html

相关文章

  • 如何设置Windows操作系统TIME_WAIT状态的TCP连接快速回收时间?
    大规模Windows环境下,采用Nginx反向代理服务后,操作系统会产生较多TIME_WAIT的TCP(TransmissionControlProtocol)连接,操作系统默认TIME_WAIT的TCP连接回收时间是4分钟,TCP默认动态端口范围为开始端口49152,结束端口65535。这样会使回收TCP过慢导致系统吞吐量下降,甚至出现502访问失败问......
  • 详解C#中 Thread,Task,Async/Await,IAsyncResult的那些事儿
    说起异步,Thread,Task,async/await,IAsyncResult这些东西肯定是绕不开的,今天就来依次聊聊他们1.线程(Thread)多线程的意义在于一个应用程序中,有多个执行部分可以同时执行;对于比较耗时的操作(例如io,数据库操作),或者等待响应(如WCF通信)的操作,可以单独开启后台线程来执行,这样主线程就不会......
  • c++ condition_variable wait unique_lock,cv.notifyall()
    #include<atomic>#include<chrono>#include<cmath>#include<condition_variable>#include<cstddef>#include<forward_list>#include<fstream>#include<functional>#include<future>#include<iom......
  • 【JavaScript】setTimeout 和 setInterval 小记
    项目setTimeoutsetInterval名称一次性定时器循环定时器相同在规定延迟时间再执行某个操作在规定延迟时间再执行某个操作区别只能定时一次可以一直循环执行下去......
  • iostat相关参数说明——await:平均每次设备I/O操作的等待时间 (毫秒),如果%util接近 100
    iostat是I/Ostatistics(输入/输出统计)的缩写,iostat工具将对系统的磁盘操作活动进行监视。它的特点是汇报磁盘活动统计情况,同时也会汇报出CPU使用情况。同vmstat一样,iostat也有一个弱点,就是它不能对某个进程进行深入分析,仅对系统的整体情况进行分析。iostat的语法如下:iostat[......
  • 为什么会出现 setTimeout 倒计时误差
    setTimeout倒计时误差的出现主要与JavaScript的事件循环机制和计时器的执行方式有关。在JavaScript中,事件循环是用于管理和调度代码执行的机制。setTimeout函数用于设置一个定时器,在指定的延迟时间后执行回调函数。然而,由于事件循环的机制,setTimeout并不能保证在准确的时......
  • async await重新理解
    去年python学asyncawait时候完全没有理解,写出来很多伪异步代码,现在重新理解await是挂起当前协程,然后运行其他携程示例1#定义一个异步函数asyncdefcount_up_to(number):print("开始计数")foriinrange(1,number+1):print(i)awaitasyncio......
  • postgresql 的 idle_session_timeout 与连接池的 max-ide-time参数
    看下面的异常:下面的错误说:terminatingconnectionduetoidle-sessiontimeout下面的这个错误说:Causedby:reactor.pool.PoolShutdownException:Poolhasbeenshutdownreactor.core.Exceptions$ErrorCallbackNotImplemented:org.springframework.dao.DataAccessResou......
  • __bp_precmd_invoke_cmd:未找到命令;__bp_interactive_mode:未找到命令
    环境Ubuntu20.04问题描述命令行输入什么指令都会提示未找到命令解决方法修改配置文件.bashrcvim.bashrc在文件尾添加unsetPROMPT_COMMAND生效配置source.bashrc......
  • ES transport client底层是netty实现,netty本质上是异步方式,但是netty自身可以使用sync
    EStransportclient底层是netty实现,netty本质上是异步方式,但是netty自身可以使用sync或者await(future超时机制)来实现类似同步调用!因此,EStransportclient可以同步调用也可以异步(不过底层的socket必然是异步实现)。发送端例子对于javaclient的数据发送(这里以bulk为例),写过的人都知......