网站首页 > 技术文章 正文
作者:太阳
三、多版本并发控制
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服务
猜你喜欢
- 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学习笔记
- 2024-11-01 Oracle数据库:揭秘大数据管理神器
- 2024-11-01 java并发编程-学习方法、进程和线程的区别
- 2024-11-01 Java高并发编程详解:深入理解并发核心库,文字可复制,高清PDF
- 2024-11-01 Spark jdbc 的并发的问题 spark jdbc server
你 发表评论:
欢迎- 632℃几个Oracle空值处理函数 oracle处理null值的函数
- 625℃Oracle分析函数之Lag和Lead()使用
- 614℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 608℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 606℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 598℃【数据统计分析】详解Oracle分组函数之CUBE
- 588℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 572℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
-
- oracle 19cOCM认证有哪些内容(oracle认证ocm月薪)
- Oracle新出AI课程认证,转型要持续学习
- oracle 表的查询join顺序,可能会影响查询效率
- Oracle DatabaseAmazon Web Services正式可用,Oracle数据库上云更容易了
- Oracle 19.28 RU 升级最佳实践指南
- 汉得信息:发布EBS系统安装启用JWS的高效解决方案
- 如何主导设计一个亿级高并发系统架构-数据存储架构(三)
- Java 后端开发必看!工厂设计模式轻松拿捏
- ORA-00600 「25027」 「x」报错(抱错孩子电视剧 爸爸是武术 另一个爸爸是画家)
- 新项目终于用上了jdk24(jdk新建项目)
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- 前端获取当前时间 (50)
- Oracle RAC (76)
- oracle恢复 (77)
- oracle 删除表 (52)
- oracle 用户名 (80)
- oracle 工具 (55)
- oracle 内存 (55)
- oracle 导出表 (62)
- oracle约束 (54)
- oracle 中文 (51)
- oracle链接 (54)
- oracle的函数 (58)
- 前端调试 (52)
本文暂时没有评论,来添加一个吧(●'◡'●)