golang mysql自动重连_golang mysql unexpected EOF(invalid connection)

1.问题

在使用go-sql-driver/mysql连接MySQL 服务过程,隔一段时间,会报MySQL连接错误:

[mysql] 2020/05/09 02:02:01 packets.go:36: unexpected EOF

2020-05-09 02:02:01 ERROR goroutine 59835131 invalid connection

排查下来,是由于使用无效的连接导致的。

基本场景是:

client 连接MySQL,执行SQL后,不立刻关闭连接。client保留连接在连接池中。

接着,MySQL服务发生重启,

或者连接超过最大时长(由wait_timeout定义,一般是8小时), MySQL服务端关闭了连接。

下次 client 执行SQL,从连接池中拿到无效的连接,就会报以上错误。

问题验证

验证代码操作步骤如下:

首先,执行SQL。

接着,sleep 60s。

这期间,将MySQL服务重启一下。

程序 sleep 后,再次执行 SQL。

代码如下:

import (

"database/sql"

"log"

"time"

_ "github.com/go-sql-driver/mysql"

)

var DB *sql.DB

var dataBase = "root:Aa123456@tcp(192

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值