💡
原文英文,约1400词,阅读约需5分钟。
📝
内容提要
Postgres使用“堆”方法存储数据,每个表分为8Kb的页面。Vacuum过程释放页面上的空间并更新表的空闲空间图和可见性图。Vacuum可以自动或手动执行。为了释放文件系统空间,可以使用更积极的VACUUM FULL模式。可以调整自动清理参数来控制何时和多久自动清理运行。长时间运行的事务和锁可能会阻止自动清理成功。其他优化包括调整自动清理工作进程的数量和增加autovacuum_work_mem参数。Vacuum和自动清理是维护表和防止膨胀的有效方法。
🎯
关键要点
- Postgres使用堆方法存储数据,每个表分为8Kb的页面。
- Vacuum过程释放页面上的空间并更新表的空闲空间图和可见性图。
- Vacuum可以自动或手动执行,VACUUM FULL模式可以更积极地释放文件系统空间。
- 长时间运行的事务和锁可能会阻止自动清理成功。
- 可以调整自动清理参数来控制自动清理的运行时机和频率。
- Vacuum通过标记关系文件中的空间为可用来清理旧行版本。
- pg_repack扩展可以在不需要完全锁定的情况下进行表的重建。
- 可以通过Supabase CLI检查数据库膨胀情况。
- autovacuum的启动基于多个配置参数,如超时和访问模式。
- 长时间运行的事务可能导致autovacuum无法成功,导致数据库膨胀。
- 可以通过增加autovacuum工作进程数量和调整autovacuum_work_mem参数来优化清理过程。
- Vacuum和自动清理是维护表和防止膨胀的有效方法。
➡️