登录
首页 >  数据库 >  MySQL

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

来源:脚本之家

时间:2023-02-25 08:46:04 361浏览 收藏

你在学习数据库相关的知识吗?本文《Mysql连接无效(invalidconnection)问题及解决》,主要介绍的内容就涉及到connection、Mysql连接无效、invalid,如果你想提升自己的开发能力,就不要错过这篇文章,大家要知道编程理论基础和实战操作都是不可或缺的哦!

Mysql连接无效invalid connection

一般连接数据库的代码库都有实现连接池,如golang语言database/sql库,其中SetConnMaxLifetime(d time.Duration)是用来设置连接池里每条连接关闭的时间,当d

当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

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

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

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持golang学习网。

文中关于mysql的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《Mysql连接无效(invalidconnection)问题及解决》文章吧,也可关注golang学习网公众号了解相关技术文章。

声明:本文转载于:脚本之家 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>