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

当使用Go语言的go-sql-driver/mysql连接MySQL时,长时间未关闭的连接在MySQL服务重启或超时后会失效。本文介绍了两种解决方案:升级mysql driver至1.5版本以自动标记并重连问题连接,或通过SetConnMaxLifetime设置连接复用时间来避免使用无效连接。
摘要由CSDN通过智能技术生成

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:[email protected](19

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值