• Ukieweb

    佳的博客

    曾梦想仗剑天涯,后来工作忙没去。

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
0
下一篇:Notepad++找回自动保存缓存内容的文件

0 条评论

老佳啊

85后,大专学历,中原人士,家里没矿。

由于年轻时长的比较帅气,导致在别人眼里,我一直不谈恋爱的原因是清高,实则是自己的小自卑。最大的人生目标就是找一个相知相爱相容的人,共度余生。

和人相处时如果能感受到真诚,会非常注重彼此的关系,对别人没有什么心机,即使有利益冲突,一般也会以和为贵,因为在这个世界上,物质的东西,从来不会吸引到我。

特别迷恋那些大山大水,如果现在还能隐居,可能早就去了。对那些宏伟的有底蕴的人文景观比较不感冒。

从事于IT行业,却一直对厨房念念不忘,由于身材魁梧,总觉得自己上辈子是个将军,可惜这辈子没当兵,也不会打架。