欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PostgreSQL 自動(dòng)Vacuum配置方式

 更新時(shí)間:2021年01月26日 16:45:23   作者:零零喵  
這篇文章主要介紹了PostgreSQL 自動(dòng)Vacuum配置方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧

PostgreSQL的Vacuum由于以下原因需要定期執(zhí)行。

釋放,再利用因更新或者刪除更新而占用的磁盤空間。

更新PostgreSQL 查詢計(jì)劃用的統(tǒng)計(jì)數(shù)據(jù)。

避免事務(wù)ID的重置而引起非常老的數(shù)據(jù)丟失。

VACUUM 的標(biāo)準(zhǔn)SQL文的執(zhí)行和其他的對(duì)數(shù)據(jù)庫的實(shí)際操作可以并行處理。

SELECT 、INSERT 、UPDATE 、DELETE 等命令和同通常一樣繼續(xù)能夠執(zhí)行。

但是,VACUUM處理中的時(shí)候, ALTER TABLE ADD COLUMN等等的命令不能夠?qū)Ρ磉M(jìn)行重新定義。

還有,由于執(zhí)行VACUUM 的時(shí)候,有大量的I/O操作,其他的操作可能性能比較低,比如查詢的反應(yīng)非常慢。為了較少對(duì)性能的影響,可以通過參數(shù)來調(diào)整。

autovacuum (boolean ):

數(shù)據(jù)庫服務(wù)器是否設(shè)置為自動(dòng)vacuum。默認(rèn)為 自動(dòng)vacuum。 但是如果要讓vacuum能夠正常運(yùn)轉(zhuǎn),必須使 track_counts 有效。 track_counts這個(gè)參數(shù)在 postgresql.conf配置文件內(nèi),或者通過命令來設(shè)置。

即使設(shè)置不是自動(dòng)vacuum。系統(tǒng)發(fā)現(xiàn)有防止事務(wù)ID的重置的必要的時(shí)候也會(huì)自動(dòng)啟動(dòng)

log_autovacuum_min_duration (integer ):

設(shè)置執(zhí)行時(shí)間超過多長(zhǎng) 的vacuum才輸出log。時(shí)間單位毫秒。

如果這個(gè)參數(shù)設(shè)置為0的話,所有vacuum相關(guān) 的log都輸出。

如果這個(gè)參數(shù)設(shè)置為-1的話,這個(gè)也是默認(rèn)設(shè)置。log的輸出無效,也就是所有vacuum相關(guān) 的log都不輸出。

這個(gè)參數(shù)的設(shè)置可以修改postgresql.conf配置文件,也可以通過命令來設(shè)置。

autovacuum_max_workers (integer ):

設(shè)置能夠同時(shí)執(zhí)行的vacuum最大進(jìn)程數(shù)。 默認(rèn)是3個(gè)。

這個(gè)參數(shù)的設(shè)置可以修改postgresql.conf配置文件,也可以通過命令來設(shè)置。

autovacuum_naptime (integer ):

設(shè)置數(shù)據(jù)庫執(zhí)行vacuum的最小延遲。時(shí)間單位是分。默認(rèn)是1分鐘。這個(gè)參數(shù)的設(shè)置可以修改postgresql.conf配置文件,也可以通過命令來設(shè)置。

autovacuum_vacuum_threshold (integer ):

設(shè)置任何一張表內(nèi)觸發(fā)VACUUM 的 更新,刪除tuple的最小數(shù)。默認(rèn)為50。

這個(gè)參數(shù)的設(shè)置可以修改postgresql.conf配置文件,也可以通過命令來設(shè)置。這個(gè)設(shè)定通過 pg_autovacuum的項(xiàng)目可以覆蓋每張表。

autovacuum_analyze_threshold (integer ):

設(shè)置任何一張表內(nèi)觸發(fā)ANALYZE 的更新,刪除tuple的最小數(shù)。默認(rèn)為50。

這個(gè)參數(shù)的設(shè)置可以修改postgresql.conf配置文件,也可以通過命令來設(shè)置。這個(gè)設(shè)定通過 pg_autovacuum的項(xiàng)目可以覆蓋每張表。

autovacuum_vacuum_scale_factor (floating point ):

是否觸發(fā)VACUUM的判斷的時(shí)候 、設(shè)置 autovacuum_vacuum_threshold 追加的表容量斷片。默認(rèn)是0.2(即20%)。

這個(gè)參數(shù)的設(shè)置可以修改postgresql.conf配置文件,也可以通過命令來設(shè)置。這個(gè)設(shè)定通過 pg_autovacuum的項(xiàng)目可以覆蓋每張表。

autovacuum_analyze_scale_factor (floating point ):

是否觸發(fā) ANALYZE 的判斷的時(shí)候 、設(shè)置 autovacuum_vacuum_threshold 追加的表容量斷片。默認(rèn)是0.1(即10%)。

這個(gè)參數(shù)的設(shè)置可以修改postgresql.conf配置文件,也可以通過命令來設(shè)置。這個(gè)設(shè)定通過 pg_autovacuum的項(xiàng)目可以覆蓋每張表。

autovacuum_freeze_max_age (integer ):

為了防止事務(wù)ID的重置,VACUUM強(qiáng)制操作前,設(shè)置表的 pg_class .relfrozenxid字段的最大值。默認(rèn)是2億。

這個(gè)參數(shù)只能夠在啟動(dòng)的時(shí)候設(shè)置。

autovacuum_vacuum_cost_delay (integer ):

設(shè)置自動(dòng)vacuum操作中cost延遲。默認(rèn)是20毫秒。設(shè)置的為-1的話,使用vacuum_cost_delay的值。

這個(gè)參數(shù)的設(shè)置可以修改postgresql.conf配置文件,也可以通過命令來設(shè)置。這個(gè)設(shè)定通過 pg_autovacuum的項(xiàng)目可以覆蓋每張表。

autovacuum_vacuum_cost_limit (integer ):

設(shè)置自動(dòng)vacuum操作中cost的最大界限值。默認(rèn)是-1,這時(shí)候用vacuum_cost_limit的值。 這個(gè)參數(shù)的設(shè)置可以修改postgresql.conf配置文件,也可以通過命令來設(shè)置。這個(gè)設(shè)定通過 pg_autovacuum的項(xiàng)目可以覆蓋每張表。

補(bǔ)充:PostgreSQL數(shù)據(jù)庫管理:定期vacuum

為什么PostgreSQL數(shù)據(jù)庫管理工作中,定期vacuum是一個(gè)重要的工作.

原因在于以下3點(diǎn):

釋放,再利用 更新/刪除的行所占據(jù)的磁盤空間.

更新PostgreSQL查詢計(jì)劃中使用的統(tǒng)計(jì)數(shù)據(jù).

防止因事務(wù)ID的重置而使非常老的數(shù)據(jù)丟失.

第一點(diǎn)的原因是

PostgreSQL數(shù)據(jù)的插入,更新,刪除操作并不是真正放到數(shù)據(jù)庫空間.如果不定期釋放空間的話,由于數(shù)據(jù)太多,查詢速度會(huì)巨降.

第二點(diǎn)的原因是

PostgreSQL在做查詢處理的時(shí)候,為了是查詢速度提高,會(huì)根據(jù)統(tǒng)計(jì)數(shù)據(jù)來確定執(zhí)行計(jì)劃.如果不及時(shí)更新的話,查詢的效果可能不如預(yù)期.

第三點(diǎn)的原因是

PostgreSQL中每一個(gè)事務(wù)都會(huì)產(chǎn)生一個(gè)事務(wù)ID,但這個(gè)數(shù)字是有上限的. 當(dāng)事務(wù)ID達(dá)到最大值后,會(huì)重新從最小值開始循環(huán).這樣如果不及時(shí)把以前的數(shù)據(jù)釋放掉的話,原來的老數(shù)據(jù)會(huì)因?yàn)槭聞?wù)ID的丟失而丟失掉.

話說回來vacuum操作可以手動(dòng)和自動(dòng).如果有專門的數(shù)據(jù)庫維護(hù)人員的話,可以適時(shí)進(jìn)行.但很多系統(tǒng)為了節(jié)省維護(hù)成本,這樣就需要依賴自動(dòng)vacuum了.

雖說定期vacuum是PostgreSQL的一個(gè)弱點(diǎn),不過在8.3版本以后,把這個(gè)任務(wù)交給自動(dòng)vacuum就可以了.

要使自動(dòng)vacuum有效,必須設(shè)置track_counts參數(shù)為true.具體的設(shè)置可以參照官方的文檔.

定期vacuum還是自己寫一個(gè)shell來自動(dòng)執(zhí)行比較好.

在shell中執(zhí)行vacuumdb命令. 例: ./vacuumdb -d databaseName --analyze

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。

相關(guān)文章

  • Postgresql的pl/pgql使用操作--將多條執(zhí)行語句作為一個(gè)事務(wù)

    Postgresql的pl/pgql使用操作--將多條執(zhí)行語句作為一個(gè)事務(wù)

    這篇文章主要介紹了Postgresql的pl/pgql使用操作--將多條執(zhí)行語句作為一個(gè)事務(wù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • postgreSQL使用pgAdmin備份服務(wù)器數(shù)據(jù)的方法

    postgreSQL使用pgAdmin備份服務(wù)器數(shù)據(jù)的方法

    這篇文章主要介紹了postgreSQL使用pgAdmin備份服務(wù)器數(shù)據(jù)的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-02-02
  • postgresql insert into select無法使用并行查詢的解決

    postgresql insert into select無法使用并行查詢的解決

    這篇文章主要介紹了postgresql insert into select無法使用并行查詢的解決,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • PostgreSQL如何按照某一字段去重,并顯示其他字段信息

    PostgreSQL如何按照某一字段去重,并顯示其他字段信息

    這篇文章主要介紹了PostgreSQL如何按照某一字段去重,并顯示其他字段信息問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • PostgreSQL 流復(fù)制異步轉(zhuǎn)同步的操作

    PostgreSQL 流復(fù)制異步轉(zhuǎn)同步的操作

    這篇文章主要介紹了PostgreSQL 流復(fù)制異步轉(zhuǎn)同步的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-12-12
  • 解決postgresql 自增id作為key重復(fù)的問題

    解決postgresql 自增id作為key重復(fù)的問題

    這篇文章主要介紹了解決postgresql 自增id作為key重復(fù)的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2021-02-02
  • PostgreSQL出現(xiàn)死鎖該如何解決

    PostgreSQL出現(xiàn)死鎖該如何解決

    昨天在對(duì)一張表執(zhí)行一條update語句的時(shí)候,沒有修改成功,直接終止執(zhí)行,就瘋狂點(diǎn)擊執(zhí)行,執(zhí)行了很多次這條語句導(dǎo)致了表被死鎖了,這篇文章主要給大家介紹了關(guān)于PostgreSQL出現(xiàn)死鎖該如何解決的相關(guān)資料,需要的朋友可以參考下
    2022-05-05
  • 如何為PostgreSQL的表自動(dòng)添加分區(qū)

    如何為PostgreSQL的表自動(dòng)添加分區(qū)

    這篇文章主要介紹了如何為PostgreSQL的表自動(dòng)添加分區(qū),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-01-01
  • 解決PostgreSQL日志信息占用磁盤過大的問題

    解決PostgreSQL日志信息占用磁盤過大的問題

    解決PostgreSQL日志信息占用磁盤過大的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • PostgreSQL批量update與oracle差異詳解

    PostgreSQL批量update與oracle差異詳解

    這篇文章主要介紹了PostgreSQL批量update與oracle差異,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-01-01

最新評(píng)論