0

0

SQL数据库历史版本膨胀_MVCC副作用

冰川箭仙

冰川箭仙

发布时间:2026-01-09 21:39:28

|

517人浏览过

|

来源于php中文网

原创

PostgreSQL易发生历史版本膨胀,因其MVCC将旧版本保留在原数据页标记为dead,依赖vacuum清理;而MySQL将旧版本存于独立undo表空间,主表仅存最新版。

sql数据库历史版本膨胀_mvcc副作用

PostgreSQL 的 MVCC 机制本身不是问题,但它是历史版本膨胀的直接源头。它不删旧数据,而是标记为“死元组”,等 vacuum 清理——如果清理跟不上,就堆出“虚胖”。

为什么 PG 容易膨胀,而 MySQL 不明显?

关键在 MVCC 实现方式不同:

  • MySQL InnoDB 把旧版本存进独立的 undo 表空间,主表只存最新版,物理文件基本不膨胀;
  • PostgreSQL 直接把旧版本保留在原数据页里,标记 dead 但不立即移走,导致同一张表里混着大量无效数据;
  • 这种设计换来了瞬时回滚、无需预估 undo 空间等优势,代价就是必须靠 vacuum 主动“打扫”。

哪些操作最容易触发膨胀?

不是所有写入都一样,以下三类最危险:

  • 高频 UPDATE/DELETE:每改一行就多一个死元组,尤其更新主键或索引字段时,还会连带产生索引膨胀;
  • 长事务未结束:只要有一个事务还在运行(哪怕只是 SELECT),vacuum 就不敢清理它可能用到的旧版本,死元组越积越多;
  • autovacuum 配置过松:比如 autovacuum_vacuum_scale_factor 设成 0.2(默认值),意味着表增长 20% 才触发 vacuum,对大表等于“等死”。

膨胀不只是占空间,它会层层恶化性能

一旦开始膨胀,影响是连锁的:

Subversion安装使用说明文档 WORD版
Subversion安装使用说明文档 WORD版

本文档主要讲述的是Subversion安装使用说明文档;Subversion是一个自由/开源的版本控制系统,正逐步替代CVS。Subversion的版本库可以通过网络访问,从而使用户可以在不同的电脑上进行操作。 Subversion可支持版本化的目录、真实的版本历史、原子提交、版本化的无数据、可选的网络层、一致的数据操作、高效的分支和标签操作和可修改性。希望本文档会给有需要的朋友带来帮助;感兴趣的朋友可以过来看看

下载
  • 顺序扫描变慢:即使查 10 行有效数据,也可能扫完整个 100GB 表文件,因为要跳过大量 dead 元组;
  • 索引失效:B-tree 索引指向的可能是已 dead 的行,查询命中索引后还得回表过滤,实际变成“假索引”;
  • VACUUM 自身变重:膨胀越严重,一次 vacuum 越耗 CPU 和 I/O,可能拖慢业务,甚至引发锁等待;
  • 极端情况触发事务 ID 回卷:pg_xact 文件里的事务号快用完却清不掉旧元组,数据库会强制只读保护,服务中断。

怎么快速判断是不是膨胀了?

别猜,用系统视图看真实数据:

  • 先装扩展:CREATE EXTENSION pgstattuple;
  • 查单表:SELECT * FROM pgstattuple('schema.table_name'); 关注 dead_tuple_countdead_tuple_percent
  • 批量筛查:SELECT schemaname||'.'||relname, n_dead_tup, pg_size_pretty(pg_total_relation_size(oid)) FROM pg_stat_all_tables ORDER BY n_dead_tup DESC LIMIT 10;

死元组占比超 10%,或绝对数量达百万级,就该干预了。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

676

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

320

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

346

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1094

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

357

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

675

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

571

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

413

2024.04.29

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

3

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.7万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 785人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号