創(chuàng)新互聯(lián)專注于企業(yè)成都全網(wǎng)營(yíng)銷推廣、網(wǎng)站重做改版、福山網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、H5建站、成都做商城網(wǎng)站、集團(tuán)公司官網(wǎng)建設(shè)、外貿(mào)網(wǎng)站建設(shè)、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁(yè)設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為福山等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。golang在進(jìn)行數(shù)據(jù)庫(kù)操作,一般來(lái)說(shuō)我們使用Open函數(shù)創(chuàng)建一個(gè)數(shù)據(jù)庫(kù)(操作)句柄:func Open(driverName, dataSourceName string) (*DB, error) 我們知道,返回的*DB是一個(gè)具有零到多個(gè)底層連接的連接池,可以安全的被多個(gè)go程使用,并且會(huì)維護(hù)自身的閑置連接。所以一般來(lái)說(shuō)open函數(shù)我們只調(diào)用一次,幾乎很少需要關(guān)閉DB。 連接池可以使得連接更好的控制,于是簡(jiǎn)單配置甚至是不做什么配置就可以用了,事實(shí)好像也是如此,連上數(shù)據(jù)庫(kù)就都o(jì)k了。但是!你很可能會(huì)遇到下面這樣的錯(cuò)誤: [mysql] 2017/01/15 12:23:43 packets.go:124: write tcp 127.0.0.1:45697->127.0.0.1:3306:write: broken pipe 其原因很有可能就是你的連接池沒有做好相關(guān)配置,或者配置了卻設(shè)置的值不對(duì),那么超時(shí)的原因大概有以下幾點(diǎn): 1.大連接數(shù)大于數(shù)據(jù)庫(kù)服務(wù)器端配置的大連接數(shù),多余的連接在被使用到的時(shí)候出現(xiàn)連接超時(shí) 2.網(wǎng)絡(luò)抖動(dòng):每次連接的時(shí)候提交或維護(hù)大量數(shù)據(jù),此時(shí)網(wǎng)絡(luò)不穩(wěn)定導(dǎo)致連接超時(shí) 3.占用的資源未被釋放,我們一般只open一次,獲取一個(gè)*DB,但是在使用stmt,rows或者是tx時(shí)候用完沒有關(guān)閉,耗盡資源也有可能導(dǎo)致連接超時(shí)。 對(duì)于出現(xiàn)的3中問題,你可以試試下面的解決方案: 1.對(duì)于大連接數(shù)的問題,調(diào)用函數(shù)Db.SetMaxOpenConns()設(shè)置值(小于數(shù)據(jù)庫(kù)配置的大連接) 2.對(duì)于維護(hù)大量數(shù)據(jù),可以嘗試采用事務(wù)操作,若失敗,回滾。然后重試。 3.使用defer關(guān)鍵字,在啟用操作的時(shí)候直接在下一行加上defer *.close()函數(shù)return的時(shí)候會(huì)執(zhí)行相關(guān)的關(guān)閉函數(shù)。 如果你嘗試了以上的解決方案,還是發(fā)現(xiàn)偶爾會(huì)出現(xiàn)連接超時(shí)的錯(cuò)誤的話,很可能是因?yàn)閿?shù)據(jù)庫(kù)本身對(duì)連接有一個(gè)超時(shí)時(shí)間的設(shè)置,如果超時(shí)時(shí)間到了數(shù)據(jù)庫(kù)會(huì)單方面斷掉連接,此時(shí)再用連接池內(nèi)的連接進(jìn)行訪問就會(huì)出錯(cuò),
連接池中的每個(gè)連接都維護(hù)了一個(gè)創(chuàng)建時(shí)間,取連接的時(shí)候會(huì)自動(dòng)檢查的,你可以試試調(diào)用db的SetConnMaxLifetime()方法來(lái)給db設(shè)置一個(gè)超時(shí)時(shí)間,時(shí)間小于數(shù)據(jù)庫(kù)的超時(shí)時(shí)間即可。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。
當(dāng)前名稱:golang:連接數(shù)據(jù)庫(kù)閑置斷線的問題-創(chuàng)新互聯(lián)
鏈接分享:http://jinyejixie.com/article30/ccsoso.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站設(shè)計(jì)、動(dòng)態(tài)網(wǎng)站、企業(yè)建站、手機(jī)網(wǎng)站建設(shè)、品牌網(wǎng)站建設(shè)、小程序開發(fā)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容