golang:連接數(shù)據(jù)庫閑置斷線的問題

golang在進(jìn)行數(shù)據(jù)庫操作,一般來說我們使用Open函數(shù)創(chuàng)建一個數(shù)據(jù)庫(操作)句柄:func Open(driverName, dataSourceName string) (*DB, error)
    我們知道,返回的*DB是一個具有零到多個底層連接的連接池,可以安全的被多個go程使用,并且會維護(hù)自身的閑置連接。所以一般來說open函數(shù)我們只調(diào)用一次,幾乎很少需要關(guān)閉DB。
    連接池可以使得連接更好的控制,于是簡單配置甚至是不做什么配置就可以用了,事實(shí)好像也是如此,連上數(shù)據(jù)庫就都o(jì)k了。但是!你很可能會遇到下面這樣的錯誤:
[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è)置的值不對,那么超時的原因大概有以下幾點(diǎn):
    1.最大連接數(shù)大于數(shù)據(jù)庫服務(wù)器端配置的最大連接數(shù),多余的連接在被使用到的時候出現(xiàn)連接超時
    2.網(wǎng)絡(luò)抖動:每次連接的時候提交或維護(hù)大量數(shù)據(jù),此時網(wǎng)絡(luò)不穩(wěn)定導(dǎo)致連接超時
    3.占用的資源未被釋放,我們一般只open一次,獲取一個*DB,但是在使用stmt,rows或者是tx時候用完沒有關(guān)閉,耗盡資源也有可能導(dǎo)致連接超時。
    對于出現(xiàn)的3中問題,你可以試試下面的解決方案:
    1.對于最大連接數(shù)的問題,調(diào)用函數(shù)Db.SetMaxOpenConns()設(shè)置值(小于數(shù)據(jù)庫配置的最大連接)
    2.對于維護(hù)大量數(shù)據(jù),可以嘗試采用事務(wù)操作,若失敗,回滾。然后重試。
    3.使用defer關(guān)鍵字,在啟用操作的時候直接在下一行加上defer *.close()函數(shù)return的時候會執(zhí)行相關(guān)的關(guān)閉函數(shù)。
  如果你嘗試了以上的解決方案,還是發(fā)現(xiàn)偶爾會出現(xiàn)連接超時的錯誤的話,很可能是因?yàn)閿?shù)據(jù)庫本身對連接有一個超時時間的設(shè)置,如果超時時間到了數(shù)據(jù)庫會單方面斷掉連接,此時再用連接池內(nèi)的連接進(jìn)行訪問就會出錯,連接池中的每個連接都維護(hù)了一個創(chuàng)建時間,取連接的時候會自動檢查的,你可以試試調(diào)用db的SetConnMaxLifetime()方法來給db設(shè)置一個超時時間,時間小于數(shù)據(jù)庫的超時時間即可。

網(wǎng)站欄目:golang:連接數(shù)據(jù)庫閑置斷線的問題
分享網(wǎng)址:http://muchs.cn/article42/pideec.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信公眾號、品牌網(wǎng)站設(shè)計、網(wǎng)站改版、外貿(mào)網(wǎng)站建設(shè)、自適應(yīng)網(wǎng)站、商城網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

搜索引擎優(yōu)化