阅读量:2
1. 调整MySQL服务器端超时参数
连接超时的核心原因是MySQL默认的空闲连接超时时间过长(wait_timeout和interactive_timeout默认8小时)。通过缩短这两个参数的值,可自动释放闲置连接,避免因长时间无操作导致的超时。
- 操作步骤:
编辑MySQL配置文件/etc/my.cnf(或/etc/mysql/mysql.conf.d/mysqld.cnf),在[mysqld]section添加或修改以下内容:保存后重启MySQL服务使配置生效:[mysqld] wait_timeout = 600 # 非交互式连接(如程序连接)空闲超时时间(秒) interactive_timeout = 600 # 交互式连接(如终端登录)空闲超时时间(秒) net_read_timeout = 30 # 读取数据的超时时间(秒,默认30秒,可根据网络情况调整) net_write_timeout = 60 # 写入数据的超时时间(秒,默认60秒,可根据网络情况调整)
验证参数是否修改成功:sudo systemctl restart mysqld注意:SHOW VARIABLES LIKE 'wait_timeout'; SHOW VARIABLES LIKE 'interactive_timeout';wait_timeout和interactive_timeout需根据应用场景调整(如高频访问的应用可设置为300-600秒,低频访问的可适当延长),避免频繁重建连接。
2. 检查并优化网络连接
网络延迟、丢包或防火墙拦截是导致连接超时的常见外部因素。
- 排查网络延迟:使用
ping命令测试客户端与MySQL服务器之间的网络延迟,若延迟过高(如超过100ms),需联系网络管理员解决:ping mysql_server_ip - 检查防火墙设置:确保服务器防火墙允许MySQL默认端口(3306)的TCP流量通过。以
firewalld为例,执行以下命令:若使用sudo firewall-cmd --zone=public --add-port=3306/tcp --permanent # 开放3306端口 sudo firewall-cmd --reload # 重新加载防火墙规则iptables,可执行:sudo iptables -A INPUT -p tcp --dport 3306 -j ACCEPT # 允许3306端口 sudo service iptables save # 保存规则(CentOS 7及以上可能使用firewalld) - 禁用DNS反向解析:MySQL默认会尝试解析客户端IP的主机名,若DNS服务器不稳定,会导致连接变慢。编辑
/etc/my.cnf,在[mysqld]section添加:
重启MySQL服务后,客户端连接时需使用IP地址而非域名。skip-name-resolve
3. 优化应用程序连接管理
应用程序的不当连接使用(如未释放连接、连接池配置不合理)会导致连接泄漏,最终触发超时。
- 使用连接池:通过连接池(如HikariCP、DBCP、C3P0)复用数据库连接,避免频繁创建和销毁连接的开销。以HikariCP为例,配置中需设置合理的
maximumPoolSize(最大连接数,根据服务器内存调整,如4GB内存可设置为100-200)和connectionTimeout(连接超时时间,如30秒):HikariConfig config = new HikariConfig(); config.setJdbcUrl("jdbc:mysql://localhost:3306/dbname"); config.setUsername("username"); config.setPassword("password"); config.setMaximumPoolSize(100); // 最大连接数 config.setConnectionTimeout(30000); // 连接超时时间(毫秒) HikariDataSource dataSource = new HikariDataSource(config); - 及时释放连接:若未使用连接池,需在程序中显式关闭
Connection、Statement和ResultSet对象(使用try-with-resources或finally块),避免连接泄漏。
4. 增加最大连接数(可选)
若应用并发量高,MySQL默认的最大连接数(通常151)可能不足,导致新连接无法建立。可通过修改max_connections参数增加最大连接数。
- 操作步骤:
编辑/etc/my.cnf,在[mysqld]section添加或修改:重启MySQL服务生效:[mysqld] max_connections = 500 # 根据服务器内存调整(如8GB内存可设置为300-500)
验证参数:sudo systemctl restart mysqld注意:增加SHOW VARIABLES LIKE 'max_connections';max_connections会占用更多内存(每个连接约占用2-4MB),需结合服务器内存情况调整,避免内存溢出(OOM)。
5. 监控连接状态
定期监控MySQL连接状态,排查长期闲置或异常的连接,及时优化应用行为。
- 查看当前连接数:
SHOW STATUS LIKE 'Threads_connected'; # 当前活跃连接数 SHOW STATUS LIKE 'Max_used_connections'; # 历史最大连接数 - 查看闲置连接:
若发现大量SHOW PROCESSLIST; # 查看所有连接及执行的SQLSleep状态的连接(如Command列为Sleep,Time列值较大),说明应用未正确释放连接,需优化连接管理(如使用连接池或修复代码中的连接泄漏问题)。
以上就是关于“如何解决CentOS MySQL连接超时”的相关介绍,筋斗云是国内较早的云主机应用的服务商,拥有10余年行业经验,提供丰富的云服务器、租用服务器等相关产品服务。云服务器资源弹性伸缩,主机vCPU、内存性能强悍、超高I/O速度、故障秒级恢复;电子化备案,提交快速,专业团队7×24小时服务支持!
简单好用、高性价比云服务器租用链接:https://www.jindouyun.cn/product/cvm