Mysql連接無效(invalid connection)問題及解決
Mysql連接無效invalid connection
一般連接數(shù)據(jù)庫的代碼庫都有實(shí)現(xiàn)連接池,如golang語言database/sql庫,其中SetConnMaxLifetime(d time.Duration)是用來設(shè)置連接池里每條連接關(guān)閉的時間,當(dāng)d <= 0時,連接池里的連接永久重用,即永遠(yuǎn)都在連接池里,拿來就用,不管此連接是否真的有效(這里有問題,下面講)。
當(dāng)d > 0時,到了時間d才會關(guān)閉連接,把連接移出連接池,但這并不是時間一到就關(guān)閉,因?yàn)楫?dāng)連接還在使用時會等連接完成之后,等下一個清理連接周期(周期為d)時會關(guān)閉連接,移出連接池。
Mysql為了防止空閑連接過多,超過了參數(shù)mysql_connection之后會拒絕新連接,mysql會自動關(guān)閉空閉連接超過wait_timeout參數(shù)的時間,會關(guān)閉使用中超過interactive_timeout參數(shù)的連接。
由于mysql會自動關(guān)閉超時連接,所以database/sql的SetConnMaxLifetime()不能設(shè)置為永久有效,要不然連接已經(jīng)被mysql關(guān)閉了,但還是拿著失效的連接使用就會報invalid connection。
解決的方案
SetConnMaxLifetime()設(shè)置的時間小于wait_timeout就行,一般建議wait_timeout/2。
Mysql遠(yuǎn)程連接不生效
記錄一下,一般這種情況都是設(shè)置 mysql 表中對應(yīng) root 用戶的 Host 從 localhost 改為 %,但是怎么弄都不生效,沒辦法只能看看 mysql 配置文件 mysqld.cnf
里面找到了一項內(nèi)容如下圖:

把上面箭頭所指處注釋后一試,還真是這個,不知道這個什么時候設(shè)置的,太無語了。
總結(jié)
以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
win2008 R2服務(wù)器下修改MySQL 5.5數(shù)據(jù)庫data目錄的方法
這篇文章主要介紹了win2008 R2服務(wù)器下修改MySQL 5.5數(shù)據(jù)庫data目錄的方法,需要的朋友可以參考下2016-04-04
MySQL提示表不存在的解決error:1146:Table doesn‘t exist的原因和解決
在使用MySQL的過程中,有時會遇到“Table doesn't exist”(表不存在)的錯誤,錯誤代碼通常為1146,這個問題可能由多種原因引起,本文將幫助你診斷和解決這個問題,如果遇到同樣問題的小伙伴跟著小編一起來看看吧2024-12-12
解說mysql之binlog日志以及利用binlog日志恢復(fù)數(shù)據(jù)的方法
下面小編就為大家?guī)硪黄庹fmysql之binlog日志以及利用binlog日志恢復(fù)數(shù)據(jù)的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-03-03
SpringBoot連接MySQL獲取數(shù)據(jù)寫后端接口的操作方法
今天通過本文給大家介紹SpringBoot連接MySQL獲取數(shù)據(jù)寫后端接口的操作方法,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2021-11-11

