08-PG清理——Autovacuum

一、autovacuum引入

vacuum 可以清理死元组,但多久调用一次vacuum是很难界定的,对于频繁更新的表,我们需要及时的vacuum,避免积累过多的死元组而致使数据库性能下降,而且死元组过多的积累必将导致下次vacuum执行缓慢;另外,如果表不频繁更新,而频繁的执行vacuum会造成不必要的资源浪费,为此PostgreSQL引入autovacuum机制,由postmaster 拉起一个单独的进程autovacuum来根据表的死元组的阈值来自动vacuum。

[pg14@test ~]$ ps -ef | grep postgres
pg14     24216     1  0 02:36 ?        00:00:00 /app/pg14/bin/postgres -D /data/pg14
pg14     24218 24216  0 02:36 ?        00:00:00 postgres: checkpointer 
pg14     24219 24216  0 02:36 ?        00:00:00 postgres: background writer 
pg14     24220 24216  0 02:36 ?        00:00:00 postgres: walwriter 
pg14     24221 24216  0 02:36 ?        00:00:00 postgres: autovacuum launcher   <<<<<<<<<
pg14     24222 24216  0 02:36 ?        00:00:00 postgres: stats collector 
pg14     24223 24216  0 02:36 ?        00:00:00 postgres: logical replication launcher
pg14     28979 28798  0 09:14 pts/0    00:00:00 grep --color=auto postgres

二、autovacuum工作机制

1.autovacuum和手动vacuum的不同

  • autovacuum在清理完死元组之后会自动执行analyze
  • autovacuum可能是多个worker并行工作的,一个worker的工作内存就可以达到maintenance_work_mem的设定值,因此如果maintenance_work_mem设定的值很大,多个autovacuum worker并行执行会消耗很大内存,为此PostgreSQL提供专门的参数autovacuum_work_mem来限定每个worker可使用的做大内存。
  • auotvacuum不允许属于同一表的多个索引并行执行

2.autovacuum相关参数

postgres=# select name,setting from pg_settings where name like '%autovacuum%';
                 name                  |  setting  
---------------------------------------+-----------
 autovacuum                            | on
 autovacuum_analyze_scale_factor       | 0.1
 autovacuum_analyze_threshold          | 50
 autovacuum_freeze_max_age             | 200 000 000
 autovacuum_max_workers   
  • 12
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

南風_入弦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值