PostgreSQL連接數(shù)過(guò)多報(bào)錯(cuò):too many clients already的解決辦法
一、問(wèn)題描述
在使用 Navicat 連接 PostgreSQL 數(shù)據(jù)庫(kù)時(shí),突然遭遇到了一個(gè)報(bào)錯(cuò):“FATAL: sorry, too many clients already”。這一錯(cuò)誤提示表明數(shù)據(jù)庫(kù)連接數(shù)已經(jīng)達(dá)到上限,無(wú)法再創(chuàng)建新連接。為了解決這一問(wèn)題,我采取了一系列查詢和配置調(diào)整的步驟,從數(shù)據(jù)庫(kù)和程序連接池兩個(gè)方面入手。
數(shù)據(jù)庫(kù)版本和程序信息:
- 數(shù)據(jù)庫(kù)版本:PostgreSQL 11.5
查看PostgreSQL 版本 SELECT version();
- 程序語(yǔ)言和框架:Java 和 Spring Boot
二、分析問(wèn)題
1. 數(shù)據(jù)庫(kù)層面
1.1 查看連接數(shù)和連接狀態(tài)
通過(guò)查詢數(shù)據(jù)庫(kù)連接數(shù)量和連接狀態(tài),了解數(shù)據(jù)庫(kù)中活躍連接的數(shù)量以及每個(gè)連接的詳細(xì)信息,包括數(shù)據(jù)庫(kù)名稱、進(jìn)程 ID(PID)、應(yīng)用程序名稱和連接狀態(tài)。
1.2 查看連接超時(shí)時(shí)間配置
查看數(shù)據(jù)庫(kù)中空閑連接的超時(shí)時(shí)間配置,確保連接池設(shè)置合理。
2. 程序方面
通過(guò)查看程序中的數(shù)據(jù)庫(kù)連接池配置,特別是對(duì)于使用 Hikari 連接池的情況,確認(rèn)連接池的設(shè)置是否合理,以及是否需要調(diào)整連接池的參數(shù)。
三、解決問(wèn)題的步驟
查詢數(shù)據(jù)庫(kù)連接數(shù)量和連接狀態(tài): 通過(guò)執(zhí)行相關(guān) SQL 查詢,了解數(shù)據(jù)庫(kù)的連接狀況。
查詢連接超時(shí)時(shí)間配置: 通過(guò) SQL 查詢,查看數(shù)據(jù)庫(kù)中空閑連接的超時(shí)時(shí)間配置。
確認(rèn)程序連接池配置: 檢查程序中使用的連接池配置,特別是 Hikari 連接池的參數(shù),調(diào)整配置以確保連接池有效管理連接。
修改空閑連接超時(shí)時(shí)間(如有需要): 如果需要,通過(guò) SQL 命令修改數(shù)據(jù)庫(kù)中空閑連接的超時(shí)時(shí)間。
四、查詢數(shù)據(jù)庫(kù)連接數(shù)量
1. 查詢數(shù)據(jù)庫(kù)可用連接
首先,我使用以下 SQL 查詢語(yǔ)句查看當(dāng)前數(shù)據(jù)庫(kù)的可用連接數(shù)與實(shí)際連接數(shù)的差異:
SELECT max_conn - now_conn AS resi_conn FROM ( SELECT setting::int8 AS max_conn, (SELECT count(*) FROM pg_stat_activity) AS now_conn FROM pg_settings WHERE name = 'max_connections' ) t;
這有助于了解數(shù)據(jù)庫(kù)的連接狀況,以及是否需要調(diào)整連接數(shù)上限。
2. 查詢數(shù)據(jù)庫(kù)連接狀態(tài)
為了更詳細(xì)地了解當(dāng)前連接狀態(tài),我執(zhí)行了以下查詢,顯示了每個(gè)連接的數(shù)據(jù)庫(kù)名稱、進(jìn)程 ID(PID)、應(yīng)用程序名稱和連接狀態(tài):
SELECT datname, pid, application_name, state FROM pg_stat_activity;
這提供了連接池中活躍連接的詳細(xì)信息,有助于定位可能導(dǎo)致連接數(shù)過(guò)多的問(wèn)題。
3. 分組查詢連接數(shù)量
通過(guò)以下查詢,我統(tǒng)計(jì)了每個(gè)數(shù)據(jù)庫(kù)的連接數(shù),這有助于發(fā)現(xiàn)是否有特定數(shù)據(jù)庫(kù)占用了過(guò)多的連接:
SELECT datname, count(0) FROM pg_stat_activity GROUP BY datname;
4. 根據(jù)PID關(guān)閉連接
--根據(jù)PID關(guān)閉連接 select pg_terminate_backend(pid) from pg_stat_activity;
5. 空閑連接超時(shí)時(shí)間
修改空閑連接超時(shí)時(shí)間(如有需要): 如果需要,通過(guò) SQL 命令修改數(shù)據(jù)庫(kù)中空閑連接的超時(shí)時(shí)間。
-- 設(shè)置控制在事務(wù)中處于空閑狀態(tài)的會(huì)話的超時(shí)時(shí)間 ALTER SYSTEM SET idle_in_transaction_session_timeout = 30000; -- 查詢控制在事務(wù)中處于空閑狀態(tài)的會(huì)話的超時(shí)時(shí)間 SHOW idle_in_transaction_session_timeout; -- 設(shè)置控制空閑會(huì)話的超時(shí)時(shí)間 ALTER SYSTEM SET idle_session_timeout = '300s'; -- 查詢空閑會(huì)話超時(shí)時(shí)間 SHOW idle_session_timeout;
五、優(yōu)化程序連接池配置
檢查程序中使用的連接池配置,特別是對(duì)于使用 Hikari 連接池的情況。以下是一些建議的配置項(xiàng):
hikari.maximum-pool-size=10 hikari.connection-timeout=30000 hikari.minimum-idle=5 hikari.max-lifetime=1800000 hikari.idle-timeout=600000
參數(shù)配置詳解:
hikari.maximum-pool-size
: 設(shè)置連接池允許的最大連接數(shù)。建議根據(jù)實(shí)際需求適度增加或減少,確保足夠但不過(guò)多。hikari.connection-timeout
: 連接超時(shí)時(shí)間,定義連接在空閑狀態(tài)多久后被釋放,以確保連接資源的有效利用。hikari.minimum-idle
: 最小空閑連接數(shù),確保連接池始終維持一定數(shù)量的活躍連接,降低連接的創(chuàng)建和銷毀開(kāi)銷。hikari.max-lifetime
: 連接生命周期,定義連接在被釋放前可以存在的最長(zhǎng)時(shí)間,防止連接長(zhǎng)時(shí)間積累導(dǎo)致資源浪費(fèi)。hikari.idle-timeout
: 空閑連接超時(shí)時(shí)間,連接在池中空閑的最長(zhǎng)時(shí)間,超過(guò)這個(gè)時(shí)間將被釋放。
這些參數(shù)可以根據(jù)實(shí)際需求進(jìn)行調(diào)整,確保連接池能夠更好地管理和釋放連接。
通過(guò)以上步驟,我成功解決了連接數(shù)過(guò)多的報(bào)錯(cuò)問(wèn)題,并優(yōu)化了數(shù)據(jù)庫(kù)連接管理。希望這些詳細(xì)的思路和步驟對(duì)您在類似問(wèn)題的解決中有所幫助。
以上就是PostgreSQL連接數(shù)過(guò)多報(bào)錯(cuò):too many clients already的解決辦法的詳細(xì)內(nèi)容,更多關(guān)于PostgreSQL連接數(shù)過(guò)多報(bào)錯(cuò)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
postgresql實(shí)現(xiàn)對(duì)已有數(shù)據(jù)表分區(qū)處理的操作詳解
這篇文章主要為大家詳細(xì)介紹了postgresql實(shí)現(xiàn)對(duì)已有數(shù)據(jù)表分區(qū)處理的操作的相關(guān)知識(shí),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-12-12PostgreSQL如何查看事務(wù)所占有的鎖實(shí)操指南
這篇文章主要給大家介紹了關(guān)于PostgreSQL如何查看事務(wù)所占有鎖的相關(guān)資料,文中通過(guò)代碼以及圖文介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用PostgreSQL具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-10-10PostgreSQL數(shù)據(jù)庫(kù)遷移部署實(shí)戰(zhàn)教程
這篇文章主要介紹了PostgreSQL數(shù)據(jù)庫(kù)遷移部署實(shí)戰(zhàn)教程,由于項(xiàng)目本身就是基于PostgreSQL數(shù)據(jù)庫(kù)構(gòu)建的,因此數(shù)據(jù)庫(kù)遷移將變得十分便捷,接下來(lái),我將簡(jiǎn)要介紹我們的遷移步驟,需要的朋友可以參考下2023-07-07postgresql查詢自動(dòng)將大寫的名稱轉(zhuǎn)換為小寫的案例
這篇文章主要介紹了postgresql查詢自動(dòng)將大寫的名稱轉(zhuǎn)換為小寫的案例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-01-01postgresql合并string_agg函數(shù)的實(shí)例
這篇文章主要介紹了postgresql合并string_agg函數(shù)的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-01-01postgresql數(shù)據(jù)添加兩個(gè)字段聯(lián)合唯一的操作
這篇文章主要介紹了postgresql數(shù)據(jù)添加兩個(gè)字段聯(lián)合唯一的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-02-02詳解如何在Ubuntu?18.04上安裝和使用PostgreSQL
關(guān)系數(shù)據(jù)庫(kù)管理系統(tǒng)是許多網(wǎng)站和應(yīng)用程序的關(guān)鍵組件,它們提供了一種結(jié)構(gòu)化的方式來(lái)存儲(chǔ)、組織和訪問(wèn)信息,本文演示了如何在?Ubuntu?18.04?VPS?實(shí)例上安裝?Postgres,并提供了基本數(shù)據(jù)庫(kù)管理的說(shuō)明,需要的朋友可以參考下2024-07-07