go-sql-driver: invalid connection

原因1:服务端主动关闭了连接
查看mysql 超时时间

show variables like  '%timeout%';

找到 wait_timeout,单位秒
然后设置空闲连接的最大生存时间小于mysql 的超时时间

db.SetConnMaxLifetime(3600*time.Second)

原因2:并发量大于允许的最大连接数
调大允许打开的最大 连接数和闲置连接,最大闲置连接和 可以打开的最大连接数 最好保持一致

db.SetMaxIdleConns(20)
db.SetMaxOpenConns(20)

解释:go-sql-driver保持了一个连接池,如果发现有连接失效,会主动释放连接,每次会取新的连接

续集: 使用go-sql-driver/mysql包报错 unexpected EOF
报错信息:

[mysql] 2019/06/10 15:12:24 packets.go:36: unexpected EOF

还是SetConnMaxLifetime的问题导致的
谨记,小于wait_timeout。

你可能感兴趣的:(go-sql-driver: invalid connection)