go-sql-driver: invalid connection

原因1:服務(wù)端主動關(guān)閉了連接
查看mysql 超時時間

show variables like  '%timeout%';

找到 wait_timeout,單位秒
然后設(shè)置空閑連接的最大生存時間小于mysql 的超時時間

db.SetConnMaxLifetime(3600*time.Second)

原因2:并發(fā)量大于允許的最大連接數(shù)
調(diào)大允許打開的最大 連接數(shù)和閑置連接,最大閑置連接和 可以打開的最大連接數(shù) 最好保持一致

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

解釋:go-sql-driver保持了一個連接池,如果發(fā)現(xiàn)有連接失效,會主動釋放連接,每次會取新的連接

續(xù)集: 使用go-sql-driver/mysql包報錯 unexpected EOF
報錯信息:

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

還是SetConnMaxLifetime的問題導(dǎo)致的
謹(jǐn)記,小于wait_timeout。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

友情鏈接更多精彩內(nèi)容