[mysql] 2020/06/01 14:24:09 packets.go:122: closing bad idle connection: EOF
[mysql] 2020/06/01 14:24:09 connection.go:158: driver: bad connection

golang使用过程中,报错:packets.go:122: closing bad idle connection: EOF

 

查了下,大概有以下方案:

1、从连接池中拿到的是一个空闲连接,但是这个链接已经被mysql服务器中断了,中断的原因大概是sleep时间太长了,超过了wait_timeout设置的时间,如果是这种情况,那么解决办法比较简单,就是对于连接有效时长的控制,最直接的变量是: maxLifetime ,它可以用 SetConnMaxLifetime 设置连接的有效时长。当 <= 0 时,连接永久保存,默认值时 0 。如果设置了 maxLifetime 会开启连接自动清理,定时检查空闲连接池中的连接,超期的关闭连接。

2、golang驱动包的bug,这个就需要升级驱动包来解决了,据说1.5之后的,基本不会遇到这个问题,可以尝试使用go get -u进行升级(go get -u github.com/go-sql-driver/mysql)。

 

大部分是step 1就能解决的,我那边step 1解决不了,我采用step 2才解决的。

 

参考1:http://www.zhangjiee.com/blog/2020/go-mysql-closing-bad-idle-connection.html

参考2:https://blog.csdn.net/w1590191166/article/details/106034337

 

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐