PostgreSQL开发与实战(7.3)多版本并发控制3

作者:太阳

三、多版本并发控制

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那样需要保证回滚段不会被用完。

更多技术信息请查看云掣官网https://yunche.pro/?t=yrgw

相关推荐

  1. PostgreSQL开发实战(7.3版本并发控制3

    2024-03-27 19:50:01       47 阅读
  2. MVCC(版本并发控制)原理实现

    2024-03-27 19:50:01       44 阅读
  3. MVCC(版本并发控制

    2024-03-27 19:50:01       42 阅读
  4. MVCC-版本并发控制

    2024-03-27 19:50:01       39 阅读
  5. MVCC(版本并发控制

    2024-03-27 19:50:01       38 阅读
  6. mysql MVCC(版本并发控制)的实现原理

    2024-03-27 19:50:01       47 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-27 19:50:01       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-27 19:50:01       100 阅读
  3. 在Django里面运行非项目文件

    2024-03-27 19:50:01       82 阅读
  4. Python语言-面向对象

    2024-03-27 19:50:01       91 阅读

热门阅读

  1. 【二】【设计模式】建造者模式

    2024-03-27 19:50:01       34 阅读
  2. Mac OS 开启原生NTFS读写功能

    2024-03-27 19:50:01       38 阅读
  3. vue3 + ts + vite 支持低版本的浏览器

    2024-03-27 19:50:01       38 阅读
  4. Python数据分析三

    2024-03-27 19:50:01       34 阅读
  5. 软件开发工具(自考小资料)

    2024-03-27 19:50:01       34 阅读
  6. AI赋能写作:ChatGPT让论文大放异彩

    2024-03-27 19:50:01       40 阅读
  7. 5.85 BCC工具之tcprtt.py解读

    2024-03-27 19:50:01       39 阅读