亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

PostgreSQL 保持 Go 建立的連接打開

PostgreSQL 保持 Go 建立的連接打開

Go
慕森王 2023-07-31 15:58:11
使用 Go cron 包,我每秒運行以下代碼:func dbPGConnectionCount(db *sql.DB) (int64, error) {    var connectionCount int64    rows, err := db.Query(`SELECT count(1) from pg_stat_activity;`)    if err != nil {        return 0, err    }    defer rows.Close()    for rows.Next() {        err = rows.Scan(&connectionCount)        if err != nil {            return 0, err        }    }    return connectionCount, err}其中db是用于連接到 PostgreSQL 的連接池。感謝這個defer聲明,我預計 PostgreSQL 不會保持任何連接打開。然而,在啟動我的程序后不久,當我檢查時,select * from pg_stat_activity我看到每秒都會添加新的空閑查詢。我究竟做錯了什么?
查看完整描述

1 回答

?
慕尼黑的夜晚無繁華

TA貢獻1864條經驗 獲得超6個贊

你沒有做錯任何事。這就是連接池的工作原理。您defer將連接釋放回池。它有意保持打開狀態,以便下次需要數據庫時,您的應用程序不必等待新的連接握手,它可以重新使用現有的連接。這幾乎就是連接池的定義。



查看完整回答
反對 回復 2023-07-31
  • 1 回答
  • 0 關注
  • 103 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號