网站首页 > 技术文章 正文
作者:太阳
三、多版本并发控制
3.1 常见多版本并发的实现方式
第一种方式是,数据库仅保存最新版本数据,将发生变更的旧行版本数据写到其他地方如undo,当需要读取旧版本数据时,通过undo重构。oracle和MySQL就是通过undo的方式实现。
第二种方式是,数据库保存所有行版本数据,当需要读取旧版本数据时直接读取即可,数据库通过一定的机制定时回收无限的行版本数据释放物理空间。postgres数据库就是通过该方式实现,SQL Server使用的方式也类似这种方式,不过它会将旧版本数据保存在tmpdb中。
3.2 PG多版本并发控制实现原理
Postgres数据库保留旧版本数据在数据文件中,也就是对于delete操作pg数据库并不会将该记录行进行物理删除,而仅仅是做了一个删除打标而已,且每个数据行中额外存储xmin、xmax、ctid的系统信息。
每条语句执行是都会去查看当前事务的事务快照信息,事务快照反应了当前并发事务中所有活跃与非活跃的事务ID信息
clog记录了所有事务的事务状态
PG数据库根据tuple的xmin、xmax、当前的事务快照信息、clog事务状态、以及当前隔离级别,根据一定的规则确定对应tuple是否可见,其规则相对比较复杂,具体信息可见:http://www.interdb.jp/pg/pgsql05.html 中 5.6. Visibility Check Rules
3.3 PG并发版本控制所必要的一些维护操作
为了优化数据库性能,需要进行一系列操作。首先,旧版本数据需要清理,因为它们仍然存在数据文件中,这会导致查询扫描更多的数据块,从而一定程度上会导致查询变慢。另外,删除没有必要的clog可以确保数据库的清理和优化。此外,当事务达到一定上限时,必须通过冻结事务来避免事务回卷。除此之外,还需要更新FSM(Free Space Map)、VM(Visibility Map)和统计信息。FSM是空闲空间映射,以.fsm进行存储,其中包含有关每个页面可用空间容量的信息。
在PG多版本并发系统中,有一些优势,例如事务回滚可立即完成,无论事务执行了多少操作。同时,数据可以进行很多更新,不必像Oracle和InnoDB那样需要保证回滚段不会被用完。
更多技术信息请查看云掣官网云掣YunChe - 可观测运维专家 | 大数据运维托管 | 云MSP服务
猜你喜欢
- 2025-08-05 Project Loom:了解新的 Java 并发模型
- 2025-08-05 java 最近有什么新的发展(2025年6月)?
- 2025-08-05 C#并发编程经典实例,中文版高清PDF资源
- 2025-08-05 并发编程:乱序执行的那些事儿五分钟给你整明白
- 2024-11-01 Oracle优化Hints功能并行parallel(二)
- 2024-11-01 GitHub大神手打笔记:MySQL的多版本并发控制
- 2024-11-01 并发类的覆盖驱动测试代码生成 植被覆盖类型代码1112指的是
- 2024-11-01 MySQL的多版本并发控制(MVCC) mysql多版本多实例部署
- 2024-11-01 多版本并发控制(MVCC)与一致性读(二)
- 2024-11-01 SQLite学习笔记(二) sql学习笔记
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- Oracle RAC (76)
- oracle恢复 (77)
- oracle 删除表 (52)
- oracle 用户名 (80)
- oracle 工具 (55)
- oracle 内存 (55)
- oracle 导出表 (62)
- oracle约束 (54)
- oracle 中文 (51)
- oracle链接 (54)
- oracle的函数 (58)
- oracle面试 (55)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)