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