其他分享
首页 > 其他分享> > wait_timeout 和 interactive_timeout

wait_timeout 和 interactive_timeout

作者:互联网

wait_timeout 和 interactive_timeout

Table of Contents

1 参数说明

这里简单解释一下两个参数含义如下:

interactive_timeout:对于交互式客户端创建的连接, MySQL允许的最大空闲时间

wait_timeout: 非交互式客户端创建的连接,MySQL允许的最大空闲时间。

在线程启动的时候,wait_timeout 的值取自于全局设置的wait_timeout 或者全局的 interactive_timeout。

2 原代码

3 interactive_timeout覆盖wait_timeout

这个操作只会在用户登陆的时候才出现.其覆盖操作定义在函数server_mpvio_update_thd中,如下:

server_mpvio_update_thd(THD *thd, MPVIO_EXT *mpvio) do_command
{
  thd->max_client_packet_length = mpvio->max_client_packet_length;
  if (mpvio->protocol->has_client_capability(CLIENT_INTERACTIVE)) //这里做判断
    thd->variables.net_wait_timeout = thd->variables.net_interactive_timeout;//这里覆盖

这里我们可以明确看到有覆盖操作,并且我们也能看到这里的if条件是如果是CLIENT_INTERACTIVE 类型的客户端连接才会做覆盖。

这段代码是新建立线程过程中的一段。那么得出一个结论: 只有在新建立线程时,同时Client类型是CLIENT_INTERACTIVE类型时,才会用 interactive_timeout覆盖掉参数wait_timeout,其他任何情况都不会出现覆盖。

4 总结

Author: halberd.lee

Created: 2019-09-26 Thu 21:55

Validate

<style></style>

标签:interactive,timeout,覆盖,交互式,thd,wait
来源: https://www.cnblogs.com/halberd-lee/p/11594770.html