選項(xiàng) | 默認(rèn)值 | 說明 | 是否優(yōu)化 | 原因 |
---|---|---|---|---|
max_connections | 100 | 允許客戶端連接的最大數(shù)目 | 否 | 因?yàn)樵跍y試的過程中,100個(gè)連接已經(jīng)足夠 |
fsync | on | 強(qiáng)制把數(shù)據(jù)同步更新到磁盤 | 是 | 因?yàn)橄到y(tǒng)的IO壓力很大,為了更好的測試其他配置的影響,把改參數(shù)改為off |
shared_buffers | 24MB | 決定有多少內(nèi)存可以被PostgreSQL用于緩存數(shù)據(jù)(推薦內(nèi)存的1/4,不超過內(nèi)存的1/2) | 是 | 在IO壓力很大的情況下,提高該值可以減少IO |
work_mem | 1MB | 使內(nèi)部排序和一些復(fù)雜的查詢都在這個(gè)buffer中完成,不夠要適可而止,每個(gè)連接都要用這么大的 | 是 | 有助提高排序等操作的速度,并且減低IO |
effective_cache_size | 128MB | 優(yōu)化器假設(shè)一個(gè)查詢可以用的最大內(nèi)存,和shared_buffers無關(guān)(推薦內(nèi)存的1/2) | 是 | 設(shè)置稍大,優(yōu)化器更傾向使用索引掃描而不是順序掃描 |
maintenance_work_mem | 16MB | 這里定義的內(nèi)存只是被VACUUM等耗費(fèi)資源較多的命令調(diào)用時(shí)使用 | 是 | 把該值調(diào)大,能加快命令的執(zhí)行 |
wal_buffer | 768kB | 日志緩存區(qū)的大小 | 是 | 可以降低IO,如果遇上比較多的并發(fā)短事務(wù),應(yīng)該和commit_delay一起用 |
checkpoint_segments | 3 | 設(shè)置wal log的最大數(shù)量數(shù)(一個(gè)log的大小為16M) | 是 | 默認(rèn)的48M的緩存是一個(gè)嚴(yán)重的瓶頸,基本上都要設(shè)置為10以上 |
checkpoint_completion_target | 0.5 | 表示checkpoint的完成時(shí)間要在兩個(gè)checkpoint間隔時(shí)間的N%內(nèi)完成 | 是 | 能降低平均寫入的開銷 |
commit_delay | 0 | 事務(wù)提交后,日志寫到wal log上到wal_buffer寫入到磁盤的時(shí)間間隔。需要配合commit_sibling | 是 | 能夠一次寫入多個(gè)事務(wù),減少IO,提高性能 |
commit_siblings | 5 | 設(shè)置觸發(fā)commit_delay的并發(fā)事務(wù)數(shù),根據(jù)并發(fā)事務(wù)多少來配置 | 是 | 減少IO,提高性能 |
當(dāng)然我這邊也有一份前面老員工牛人整理的來看一下怎么配置。
在配置文件C:\PostgreSQL\data\pg96\postgresql.conf 中直接修改,修改前記得備份一下原文件,因?yàn)槟悴恢酪馔夂兔魈觳恢滥膫€(gè)會(huì)先來。修改完成之后,記得重啟數(shù)據(jù)庫哦。
ALTER SYSTEM SET configuration_parameter { TO | = } { value | 'value' | DEFAULT }
例如:我們現(xiàn)在要修改 maintenance_work_mem
--參數(shù) show all; show maintenance_work_mem; --注意這里的設(shè)置不會(huì)改變postgresql.conf,只會(huì)改變postgresql.conf ALTER SYSTEM SET maintenance_work_mem= 1048576; --重啟數(shù)據(jù)庫 show maintenance_work_mem; --取消postgresql.auto.conf的參數(shù)設(shè)置 ALTER SYSTEM SET maintenance_work_mem= default;
好的,那我們來
cd /home/postgres/pgsql/data cat postgresql.conf
superuser_reserved_connections = 3 unix_socket_directory = '/var/lib/pgsql/current/data/unix_socket' unix_socket_permissions = 0700 log_min_duration_statement = 10000ms deadlock_timeout = 5s track_activity_query_size = 10000 stats_temp_directory = 'pg_stat_tmp' autovacuum = on log_autovacuum_min_duration = 0 shared_preload_libraries = 'pg_stat_statements' pg_stat_statements.max = 10000 pg_stat_statements.track = all track_activities = on track_counts = on track_io_timing = on #log parameter log_destination = 'csvlog' logging_collector = on log_directory = 'pg_log' log_truncate_on_rotation = on log_rotation_age = 1d log_rotation_size = 10MB log_checkpoints = on log_lock_waits = on #性能參數(shù)調(diào)整 shared_buffers = 16384MB temp_buffers = 1024MB work_mem = 2048MB maintenance_work_mem = 4096MB
保存和重啟。因?yàn)槲业氖潜镜販y試的機(jī)器并不是最后線上的,最后線上的一定會(huì)這么用的。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
標(biāo)簽:海西 濮陽 杭州 榆林 辛集 昭通 寶雞 溫州
巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《postgresql 性能參數(shù)配置方式》,本文關(guān)鍵詞 postgresql,性能,參數(shù),配置,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。