iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >Mysql连接无效(invalid connection)问题及解决
  • 524
分享到

Mysql连接无效(invalid connection)问题及解决

Mysql连接无效MysqlinvalidconnectionMysql连接 2023-02-16 11:02:06 524人浏览 泡泡鱼
摘要

目录Mysql连接无效invalid connection解决的方案mysql远程连接不生效总结Mysql连接无效invalid connection 一般连接数据库的代码库都有实现连接池,如golang语言databa

Mysql连接无效invalid connection

一般连接数据库的代码库都有实现连接池,如golang语言database/sql库,其中SetConnMaxLifetime(d time.Duration)是用来设置连接池里每条连接关闭的时间,当d <= 0时,连接池里的连接永久重用,即永远都在连接池里,拿来就用,不管此连接是否真的有效(这里有问题,下面讲)。

当d > 0时,到了时间d才会关闭连接,把连接移出连接池,但这并不是时间一到就关闭,因为当连接还在使用时会等连接完成之后,等下一个清理连接周期(周期为d)时会关闭连接,移出连接池。

Mysql为了防止空闲连接过多,超过了参数mysql_connection之后会拒绝新连接,mysql会自动关闭空闭连接超过wait_timeout参数的时间,会关闭使用中超过interactive_timeout参数的连接。

由于mysql会自动关闭超时连接,所以database/sql的SetConnMaxLifetime()不能设置为永久有效,要不然连接已经被mysql关闭了,但还是拿着失效的连接使用就会报invalid connection。

解决的方案

SetConnMaxLifetime()设置的时间小于wait_timeout就行,一般建议wait_timeout/2。

Mysql远程连接不生效

记录一下,一般这种情况都是设置 mysql 表中对应 root 用户的 Host 从 localhost 改为 %,但是怎么弄都不生效,没办法只能看看 mysql 配置文件 mysqld.cnf

里面找到了一项内容如下图:

Mysql连接无效(invalid connection)问题及解决

把上面箭头所指处注释后一试,还真是这个,不知道这个什么时候设置的,太无语了。 

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

您可能感兴趣的文档:

--结束END--

本文标题: Mysql连接无效(invalid connection)问题及解决

本文链接: https://www.lsjlt.com/news/196333.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作