使用 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
將連接釋放回池。它有意保持打開狀態,以便下次需要數據庫時,您的應用程序不必等待新的連接握手,它可以重新使用現有的連接。這幾乎就是連接池的定義。
- 1 回答
- 0 關注
- 103 瀏覽
添加回答
舉報
0/150
提交
取消