MySQL中interactive_timeout和wait_timeout (连接数相关)
MySQL中的配置参数 interactive_timeout 和 wait_timeout ( 可能导致 sleep 进程过多的两个参数 )
MySQL 服务器所支持的最大连接数是有上限的,因为每个连接的建立都会消耗内存,因此我们希望客户端在连接到 MySQL Server 处理完相应的操作后,应该断开连接并释放占用的内存。如果你的 MySQL Server 有大量的闲置连接,他们不仅会白白消耗内存,而且如果连接一直在累加而不断开,最终肯定会达到 MySQL Server 的连接上限数,这会报 'too many connections' 的错误。
对于 wait_timeout 的值设定,应该根据系统的运行情况来判断。在系统运行一段时间后,可以通过 show processlist 命令查看当前系统的连接状态,如果发现有大量的 sleep 状态的连接进程,则说明该参数设置的过大,可以进行适当的调整小些。
interactive_timeout
参数含义:服务器关闭交互式连接前等待活动的秒数。交互式客户端定义为在 mysql_real_connect() 中使用 CLIENT_INTERACTIVE 选项的客户端。
参数默认值:28800秒(8小时)
wait_timeout
参数含义:服务器关闭非交互连接之前等待活动的秒数。
在线程启动时,根据全局wait_timeout值或全局interactive_timeout值初始化会话wait_timeout值,取决于客户端类型(由mysql_real_connect()的连接选项CLIENT_INTERACTIVE定义)。
参数默认值:28800秒(8小时)
两者生效取决于,客户端是交互或者非交互的连接。
在交互模式下,interactive_timeout 才生效;非交互模式下,wait_timeout 生效。
参数设置及查看
my.cnf
[mysqld] wait_timeout=100 interactive_timeout=100
全局变量
mysql> set global wait_timeout=100; mysql> set global interactive_timeout=100;
查看生效
mysql> show variables like "%timeout%" ;
共 0 条评论