答案是通过设置mysql服务端的wait_timeout和interactive_timeout参数来控制客户端连接超时。首先,wait_timeout用于非交互式连接,默认28800秒,可设为600实现10分钟空闲断开;其次,interactive_timeout针对交互式连接如命令行登录,建议与wait_timeout值一致;两者可通过SET GLOBAL命令临时生效,或在my.cnf/my.ini的[mysqld]段落添加配置永久生效,修改后需重启MySQL服务;此外,客户端如JDBC的connectTimeout等参数仅控制连接建立阶段超时,无法替代服务端空闲超时设置,因此核心仍在于服务端参数调整。

在 MySQL 中设置客户端连接超时,主要是通过调整服务器端的几个关键参数来控制连接空闲多久后自动断开。虽然“客户端超时”听起来像是在客户端设置,但实际上是由 MySQL 服务端控制的。
1. wait_timeout
这个参数控制非交互式连接(比如应用程序连接)在无操作状态下保持打开的秒数。
默认值通常是 28800 秒(8 小时)。
如果你希望连接在闲置 10 分钟后断开:
SET GLOBAL wait_timeout = 600;
该设置会影响所有新建立的连接。注意:这个值不会影响已经存在的连接。
2. interactive_timeout
这个参数专门用于交互式连接(如你在命令行使用 mysql 登录),控制空闲超时时间。
如果用户通过 mysql 客户端工具连接,这个值起作用。
例如设置为 600 秒:
SET GLOBAL interactive_timeout = 600;
通常建议 wait_timeout 和 interactive_timeout 设置为相同值,避免行为不一致。
3. 修改配置文件永久生效
上面的 SET GLOBAL 命令只在当前运行时有效,重启 MySQL 后会恢复默认。要永久设置,需修改 MySQL 配置文件。
编辑 my.cnf 或 my.ini(linux 一般在 /etc/my.cnf 或 /etc/mysql/my.cnf,windows 在安装目录下):
在 [mysqld] 段落下添加:
[mysqld] wait_timeout = 600 interactive_timeout = 600
保存后重启 MySQL 服务使配置生效。
4. 客户端配合设置
某些客户端(如 JDBC、python 的 pymysql)也支持设置连接超时时间,但这通常是指“连接建立阶段”的超时,而不是连接空闲超时。
例如在 JDBC 连接串中可以加:
connectTimeout=10000&socketTimeout=30000
这些是客户端网络通信的超时控制,不能替代服务端的 wait_timeout。
基本上就这些。关键是理解连接空闲超时由服务端控制,主要靠 wait_timeout 和 interactive_timeout 参数实现。改完记得重启服务或确认动态生效。


