packets.go:123: closing bad idle connection: EOF
[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 connectiongolang使用过程中,报错:packets.go:122: closing bad idle connect
[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
更多推荐
所有评论(0)