openGauss学习笔记-140 openGauss 数据库运维-例行维护-例行维护表

文章目录

    • [openGauss学习笔记-140 openGauss 数据库运维-例行维护-例行维护表](#openGauss学习笔记-140 openGauss 数据库运维-例行维护-例行维护表)
      • [140.1 相关概念](#140.1 相关概念)
      • [140.2 操作步骤](#140.2 操作步骤)
      • [140.3 维护建议](#140.3 维护建议)

openGauss学习笔记-140 openGauss 数据库运维-例行维护-例行维护表

为了保证数据库的有效运行,数据库必须在插入/删除操作后,基于客户场景,定期做VACUUM FULL和ANALYZE,更新统计信息,以便获得更优的性能。

140.1 相关概念

使用VACUUM、VACUUM FULL和ANALYZE命令定期对每个表进行维护,主要有以下原因:

  • VACUUM FULL可回收已更新或已删除的数据所占据的磁盘空间,同时将小数据文件合并。
  • VACUUM对每个表维护了一个可视化映射来跟踪包含对别的活动事务可见的数组的页。一个普通的索引扫描首先通过可视化映射来获取对应的数组,来检查是否对当前事务可见。若无法获取,再通过堆数组抓取的方式来检查。因此更新表的可视化映射,可加速唯一索引扫描。
  • VACUUM可避免执行的事务数超过数据库阈值时,事务ID重叠造成的原有数据丢失。
  • ANALYZE可收集与数据库中表内容相关的统计信息。统计结果存储在系统表PG_STATISTIC中。查询优化器会使用这些统计数据,生成最有效的执行计划。

140.2 操作步骤

  1. 使用VACUUM或VACUUM FULL命令,进行磁盘空间回收。

    • VACUUM

      对表执行VACUUM操作

      makefile 复制代码
      openGauss=# VACUUM customer;
      undefined 复制代码
      VACUUM

      可以与数据库操作命令并行运行。(执行期间,可正常使用的语句:SELECT、INSERT、UPDATE和DELETE。不可正常使用的语句:ALTER TABLE)。

      对表分区执行VACUUM操作

      makefile 复制代码
      openGauss=# VACUUM customer_par PARTITION ( P1 );
      undefined 复制代码
      VACUUM
    • VACUUM FULL

      makefile 复制代码
      openGauss=# VACUUM FULL customer;
      undefined 复制代码
      VACUUM

      需要向正在执行的表增加排他锁,且需要停止其他所有数据库操作。

  2. 使用ANALYZE语句更新统计信息。

    makefile 复制代码
    openGauss=# ANALYZE customer;
    undefined 复制代码
    ANALYZE

    使用ANALYZE VERBOSE语句更新统计信息,并输出表的相关信息。

    makefile 复制代码
    openGauss=# ANALYZE VERBOSE customer;
    undefined 复制代码
    ANALYZE

    也可以同时执行VACUUM ANALYZE命令进行查询优化。

    makefile 复制代码
    openGauss=# VACUUM ANALYZE customer;
    undefined 复制代码
    VACUUM

    说明: VACUUM和ANALYZE会导致I/O流量的大幅增加,这可能会影响其他活动会话的性能。因此,建议通过"vacuum_cost_delay"参数设置《数据库参考》中"GUC参数说明 > 资源消耗 > 基于开销的清理延迟"。

  3. 删除表。

    makefile 复制代码
    openGauss=# DROP TABLE customer;
    openGauss=# DROP TABLE customer_par;
    openGauss=# DROP TABLE part;

    当结果显示为如下信息,则表示删除成功。

    sql 复制代码
    DROP TABLE

140.3 维护建议

  • 定期对部分大表做VACUUM FULL,在性能下降后为全库做VACUUM FULL,目前暂定每月做一次VACUUM FULL。
  • 定期对系统表做VACUUM FULL,主要是PG_ATTRIBUTE。
  • 启用系统自动清理线程(AUTOVACUUM)自动执行VACUUM和ANALYZE,回收被标识为删除状态的记录空间,并更新表的统计数据。

👍 点赞,你的认可是我创作的动力!

⭐️ 收藏,你的青睐是我努力的方向!

✏️ 评论,你的意见是我进步的财富!

相关推荐
Leo July9 分钟前
【MySQL】MySQL数据库调优实战指南:从基础优化到架构升级
数据库·mysql·架构
l1t15 分钟前
DeepSeek总结的在单节点上处理 1TB Parquet 数据方法
数据库·人工智能·duckdb
么么...19 分钟前
系统性 MySQL 优化:性能分析、索引设计与失效场景全解
数据库·经验分享·sql·mysql
heartbeat..25 分钟前
数据库性能优化:优化的时机(表结构+SQL语句+系统配置与硬件)
java·数据库·mysql·性能优化
YongCheng_Liang25 分钟前
分布式数据库核心原理深度解析:架构、理论与事务解决方案
运维·数据库·sql
UrSpecial27 分钟前
IM项目——文件管理子服务
服务器·数据库·oracle
一个响当当的名号28 分钟前
lectrue6 缓冲池
数据库
小唐同学爱学习29 分钟前
缓存与数据库一致性问题
java·数据库·spring boot·缓存
Traced back34 分钟前
Windows窗体应用 + SQL Server 自动清理功能方案:按数量与按日期双模式
数据库·windows·c#·.net
观远数据40 分钟前
在线数据分析网站有哪些?7款自助平台选型指南
大数据·数据库·数据分析