超碰人人人人人,亚洲AV午夜福利精品一区二区,亚洲欧美综合区丁香五月1区,日韩欧美亚洲系列

LOGO OA教程 ERP教程 模切知識(shí)交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

PostgreSQL 實(shí)例安裝完,哪些配置參數(shù)需要調(diào)整?

admin
2024年12月3日 11:40 本文熱度 829

數(shù)據(jù)庫實(shí)例初始安裝完,總需要對(duì)配置參數(shù)進(jìn)行初次的設(shè)置和調(diào)整。

在本教程中,我們將回顧一些有助于 PostgreSQL 調(diào)優(yōu)的不同的 GUC(全局統(tǒng)一配置)參數(shù)。這些參數(shù)位于 postgresql.conf 文件($PGDATA目錄內(nèi))中,該文件管理著數(shù)據(jù)庫服務(wù)器的配置和性能。

shared_buffers (integer)

shared_buffers 參數(shù)確定專用于服務(wù)器緩存數(shù)據(jù)的內(nèi)存量。該參數(shù)在 postgresql.conf 文件中設(shè)置的默認(rèn)值為:

shared_buffers = 128MB

該值應(yīng)設(shè)置為機(jī)器總內(nèi)存的 15% 到 25%。例如,如果您的機(jī)器內(nèi)存大小為 32 GB,則 shared_buffers 的建議值為 8 GB。

更改此參數(shù)后,需要重新啟動(dòng)服務(wù)器。

work_mem (integer)

work_mem 參數(shù)實(shí)質(zhì)上提供了內(nèi)部排序操作和哈希表在寫入臨時(shí)的磁盤文件之前要使用的內(nèi)存量。排序操作用于 ORDER BY、DISTINCT 和 MERGE JOIN 操作。哈希表用于哈希連接和基于哈希的聚合。

該參數(shù)在 postgresql.conf 文件中設(shè)置的默認(rèn)值為:

work_mem = 4MB

設(shè)置正確的 work_mem 參數(shù)值可以減少磁盤交換,從而大大加快查詢速度。

我們可以使用下面公式,來計(jì)算數(shù)據(jù)庫服務(wù)器的 work_mem 值:

總內(nèi)存 * 0.25 / max_connections

max_connections 也是一個(gè) GUC 參數(shù),它用于指定與數(shù)據(jù)庫服務(wù)器的最大并發(fā)連接數(shù)。默認(rèn)情況下,該值設(shè)置為 100 個(gè)連接。

我們也可以直接給一個(gè)角色設(shè)置 work_mem 參數(shù)值:

ALTER USER test SET work_mem='4GB';

autovacuum

默認(rèn)情況下,該 GUC 參數(shù)在 postgresql.conf 文件中處于啟用狀態(tài),建議采用此設(shè)置。如果該參數(shù)設(shè)置為 off,則服務(wù)器中不會(huì)進(jìn)行自動(dòng)清理,但是在禁用的情況下,系統(tǒng)還是會(huì)啟動(dòng) autovacuum 進(jìn)程,以防止事務(wù) ID 回卷。

在 postgresql.conf 文件中更改此參數(shù)值后,需要重新啟動(dòng)數(shù)據(jù)庫服務(wù)器。

其他與 autovacuum 相關(guān)的 GUC 參數(shù)包括:

autovacuum_max_workers

該參數(shù)可設(shè)置會(huì)并行運(yùn)行的 autovacuum 工作進(jìn)程數(shù)。默認(rèn)情況下,它是 3。如果存在大量具有頻繁更新或刪除操作的表,則需要將該值設(shè)置得更高。

autovacuum_naptime

該參數(shù)指定在任何給定數(shù)據(jù)庫上調(diào)度 autovacuum 運(yùn)行之間的最小延遲。默認(rèn)值為 1 分鐘。如果有 60 個(gè)數(shù)據(jù)庫,則必須每秒啟動(dòng)一次 autovacuum 進(jìn)程。在這種情況下,建議增加該值,以便 autovacuum 不會(huì)太頻繁地啟動(dòng)。

autovacuum_vacuum_threshold

該參數(shù)指定在任何一個(gè)表中觸發(fā) VACUUM 所需的最少更新或刪除的元組數(shù)。默認(rèn)值為 50 個(gè)元組,這對(duì)于很多表來說是非常低的。

autovacuum_analyze_threshold

該參數(shù)指定在任何一個(gè)表中觸發(fā) ANALYZE 所需的插入、更新或刪除的元組的最少數(shù)量。默認(rèn)值為 50 個(gè)元組,這對(duì)于很多表來說是非常低的。

autovacuum_vacuum_scale_factor

該參數(shù)指定對(duì)一個(gè)表啟動(dòng) autovacuum 進(jìn)程所需更改的表的百分比。默認(rèn)值為 0.2(即表大小的 20%),autovacuum_analyze_scale_factor 為 0.1(即 10%)。該值適用于小型表,但如果表的大小較大(比如 150 GB),則在 autovacuum 進(jìn)程啟動(dòng)之前將有 30 GB 的死元組。但是,如果有少量的大型表,那么我們可以在表級(jí)別進(jìn)行設(shè)置,而不是修改 postgresql.conf 文件:

ALTER TABLE test SET (autovacuum_vacuum_scale_factor=0.1);

有關(guān)其他的 autovacuum 參數(shù),請(qǐng)參閱 PostgreSQL 在線文檔。

effective_cache_size

effective_cache_size 參數(shù)用來估計(jì)在數(shù)據(jù)庫系統(tǒng)中可被操作系統(tǒng)用于磁盤緩存的內(nèi)存量。PostgreSQL 查詢規(guī)劃器會(huì)決定它是否能放入內(nèi)存中。較高的值更有可能采用索引掃描,否則如果該值較低,則將使用順序掃描。

建議將 effective_cache_size 設(shè)置為機(jī)器總內(nèi)存的 50%。

max_parallel_worker

max_parallel_worker 參數(shù)指定要執(zhí)行并行操作的最大工作進(jìn)程數(shù),這還取決于 GUC 參數(shù) max_worker_processes 中指定的值,它指定了系統(tǒng)可以支持的最大后臺(tái)進(jìn)程數(shù);默認(rèn)值為 8。

maintenance_work_mem (integer)

maintenance_work_mem 參數(shù)實(shí)質(zhì)上提供了維護(hù)操作可使用的最大內(nèi)存量,如 VACUUM、CREATE INDEX、ALTER TABLE 和添加外鍵操作等。該參數(shù)在 postgresql.conf 文件中設(shè)置的默認(rèn)值為:

maintenance_work_mem = 64MB

建議將該值設(shè)置為高于 work_mem,這樣可能會(huì)提高 vacuum 操作的性能。一般來說,它應(yīng)該是:

總內(nèi)存 * 0.05

有關(guān)更多詳細(xì)信息,請(qǐng)參閱 PostgreSQL 調(diào)優(yōu)的 wiki 頁面。


該文章在 2024/12/4 17:30:27 編輯過
關(guān)鍵字查詢
相關(guān)文章
正在查詢...
點(diǎn)晴ERP是一款針對(duì)中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國內(nèi)大量中小企業(yè)的青睞。
點(diǎn)晴PMS碼頭管理系統(tǒng)主要針對(duì)港口碼頭集裝箱與散貨日常運(yùn)作、調(diào)度、堆場、車隊(duì)、財(cái)務(wù)費(fèi)用、相關(guān)報(bào)表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點(diǎn),圍繞調(diào)度、堆場作業(yè)而開發(fā)的。集技術(shù)的先進(jìn)性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點(diǎn)晴WMS倉儲(chǔ)管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購管理,倉儲(chǔ)管理,倉庫管理,保質(zhì)期管理,貨位管理,庫位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號(hào)管理軟件。
點(diǎn)晴免費(fèi)OA是一款軟件和通用服務(wù)都免費(fèi),不限功能、不限時(shí)間、不限用戶的免費(fèi)OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved