使用 Go cron 包,我每秒運(yùn)行以下代碼: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 的連接池。感謝這個(gè)defer聲明,我預(yù)計(jì) PostgreSQL 不會(huì)保持任何連接打開(kāi)。然而,在啟動(dòng)我的程序后不久,當(dāng)我檢查時(shí),select * from pg_stat_activity我看到每秒都會(huì)添加新的空閑查詢。我究竟做錯(cuò)了什么?
1 回答

慕尼黑的夜晚無(wú)繁華
TA貢獻(xiàn)1864條經(jīng)驗(yàn) 獲得超6個(gè)贊
你沒(méi)有做錯(cuò)任何事。這就是連接池的工作原理。您defer
將連接釋放回池。它有意保持打開(kāi)狀態(tài),以便下次需要數(shù)據(jù)庫(kù)時(shí),您的應(yīng)用程序不必等待新的連接握手,它可以重新使用現(xiàn)有的連接。這幾乎就是連接池的定義。
- 1 回答
- 0 關(guān)注
- 118 瀏覽
添加回答
舉報(bào)
0/150
提交
取消