当前位置: 首页 > news >正文

PostgreSQL 中 VACUUM FULL 对索引的影响

PostgreSQL 中 VACUUM FULL 对索引的影响

是的,VACUUM FULL 会重建表上的所有索引。这是它与普通 VACUUM 命令的一个重要区别。

一、VACUUM FULL 的工作原理

  1. 表重建过程

    • 创建表的全新副本
    • 只将有效数据写入新存储
    • 删除原始表文件
    • 将新文件重命名为原表名
  2. 索引处理

    • 在表数据完全重写后
    • 所有索引会被完全重建
    • 索引统计信息也会更新

二、与普通 VACUUM 的对比

特性VACUUMVACUUM FULL
是否锁表不锁表(并发允许)排他锁(阻塞操作)
空间回收不返还给操作系统空间返还操作系统
索引处理不重建索引完全重建所有索引
执行速度慢(尤其大表)
对系统影响

三、索引重建的影响

  1. 积极影响

    • 消除索引膨胀
    • 提高索引扫描效率
    • 更新索引统计信息
    • 优化索引结构(减少碎片)
  2. 负面影响

    • 重建期间消耗大量CPU/IO资源
    • 对大表可能导致长时间不可用
    • 需要额外的临时空间(约原表大小)

四、使用建议

  1. 适用场景

    -- 表有大量更新/删除操作后
    -- 索引明显膨胀(用pg_stat_all_indexes查看)
    -- 准备进行重要性能敏感操作前
    
  2. 替代方案

    -- 常规维护使用普通VACUUM
    VACUUM ANALYZE table_name;-- 使用CREATE TABLE...AS重建(更灵活)
    BEGIN;
    CREATE TABLE new_table AS SELECT * FROM old_table;
    DROP TABLE old_table;
    ALTER TABLE new_table RENAME TO old_table;
    -- 重建约束和索引...
    COMMIT;
    
  3. 监控方法

    -- 检查索引膨胀情况
    SELECT schemaname || '.' || relname AS table,indexrelname AS index,pg_size_pretty(pg_relation_size(indexrelid)) AS index_size,idx_scan AS index_scans
    FROM pg_stat_user_indexes
    ORDER BY pg_relation_size(indexrelid) DESC;
    

五、注意事项

  1. 生产环境慎用

    • 在低峰期执行
    • 考虑使用pg_repack扩展(在线重组)
  2. 空间需求

    -- 确保有足够空间(约原表+索引大小的2倍)
    SELECT pg_size_pretty(pg_total_relation_size('table_name'));
    
  3. 后续操作

    -- 重建后更新统计信息
    ANALYZE table_name;-- 检查重建效果
    SELECT n_dead_tup FROM pg_stat_user_tables WHERE relname = 'table_name';
    

VACUUM FULL 是强大的维护工具,但因其重建索引和锁表的特性,应在充分了解影响后谨慎使用。对于关键业务表,建议优先考虑 pg_repack 等在线重组工具。

相关文章:

  • VMware Workstation 创建虚拟机并安装 Ubuntu 系统 的详细步骤指南
  • uniapp 实现时分秒 分别倒计时
  • 从零开始学Python游戏编程48-二维数组2
  • git did not exit cleanly (exit code 128) 已解决
  • 【uniapp】在UniApp中检测手机是否安装了某个应用
  • Canvas基础篇:图形绘制
  • 卫星变轨轨迹和推力模拟(单一引力源)MATLAB
  • AI驱动的决策智能系统(AIDP)和自然语言交互式分析
  • 金融风控的“天眼”:遥感技术的创新应用
  • SAP MM 定价程序步骤及细节
  • 第二章-科学计算库NumPy
  • 华为云汪维敏:AI赋能应用现代化,加速金融生产力跃升
  • vs2019编译occ7.9.0时,出现fatal error C1060: compiler is out of heap space
  • Mysql查询异常【Truncated incorrect INTEGER value】
  • vscode详细配置Go语言相关插件
  • win11 终端 安装ffmpeg 使用终端Scoop
  • OpenCV实战教程 第一部分:基础入门
  • Java List分页工具
  • 零部件设计行业如何在数字化转型中抓住机遇?
  • LangChain 核心模块:Data Conneciton - Vector Stores
  • 聚焦各领域顶尖工匠,《上海工匠》第十季于五一播出
  • 华夏银行一季度营收降逾17%、净利降逾14%,公允价值变动损失逾24亿
  • 西夏文残碑等文物来沪,见证一段神秘灿烂的历史
  • 北京动物园:大熊猫“萌兰”没有参加日本大阪世博会的计划
  • 赛力斯拟赴港上市:去年扭亏为盈净利59亿元,三年内实现百万销量目标
  • 报告显示2024年全球军费开支增幅达冷战后最大