如何理解PostgreSQL全页写?

ops/2024/11/2 3:10:51/

  读了很多PostgreSQL的FullPageWrite过程,结果思考时把自己绕进去了。每次感觉读懂了,但是都没能理解,其实是一个很简单的逻辑。
  全页写发生在PG的Checkpoint时候,不要过于考虑全页写在checkpoint中的过程,而是单纯思考其作用,其实很好解。
  假设没开启全页写的场景下,在checkpoint完成之后,后续数据库持续读写,然后bgwriter的向底层刷脏,某个时刻刷脏异常断电,导致磁盘的页只写了部分,数据页异常不完整了。然后数据库重启之后,从redo点开始回放wal,从上次redo点开始回放,但是磁盘上的数据页本身就不完整,如何能回放成功呢?所以在每次checkpoint成功之后,第一次数据页的修改的wal日志中,对整个数据页进行备份,写到wal中。这样后续即便数据库运行过程中出现部分页写,数据页不完整的情况,那么后续起来后,反正从redo点开始回放,而回放的同时,会发现wal中有备份块,那么就会覆盖页面内容,这样也就能保证数据一致了。

问:如果checkpoint过程中崩溃了怎么办?

  这也不是问题,因为redo点只有在checkpoint成功后才会记录到pg_controldata文件中,在checkpoint过程中崩溃了,下次启动时,从上次checkpoint生成的redo点开始回放,因为上次的checkpoint完成redo点之后针对数据页第一次的修改都保存了全量数据,所以用wal中的数据页块直接覆盖本地的数据页,然后一步步回放至最近的wal记录,这样保证了数据库的一致性。


http://www.ppmy.cn/ops/130307.html

相关文章

奥数与C++小学四年级(第十六题 魔法学院)

参考程序代码&#xff1a; #include <iostream>int main() {int maxStudentsPerSubject 9; // 每个科目最多有9个比哈利高的学生int students maxStudentsPerSubject * 3; // 三个科目// 加上哈利自己int totalStudents students 1;std::cout << "最大学…

静态路由实现路由互通

静态路由 实现 pc1 ping通 pc2&#xff0c;展示静态路由效果。 默认 pc1 无法ping通 pc2 ar1 ar2 互相添加静态路由 sy Enter system view, return user view with CtrlZ. [ar1]ip route-static 2.2.2.0 255.255.255.0 12.1.1.2 sy Enter system view, return user view wit…

爬虫ip与反爬虫的“猫鼠游戏”

大家好&#xff01;在网络世界中&#xff0c;爬虫和反爬虫就像汤姆和杰瑞一样&#xff0c;他们在里面上演着一场场精彩绝伦又硝烟弥漫的“猫鼠游戏”&#xff0c;今天小蝌蚪就来带大家看看这部精彩的“猫和老鼠”。 爬虫简单来说是一种智能程序&#xff0c;它的使命就是从无数…

WPF+MVVM案例实战(十四)- 封装一个自定义消息弹窗控件(下)

文章目录 1、案例效果2、弹窗控件使用1.引入用户控件2、按钮命令实现 3、总结4、源代码获取 1、案例效果 2、弹窗控件使用 1.引入用户控件 打开 Wpf_Examples 项目&#xff0c;在引用中添加用户控件库&#xff0c;在 MainWindow.xaml 界面引用控件库&#xff0c;代码如下&…

python之爬虫遇到返回内容乱码

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言解决思路 前言 提示&#xff1a;这里可以添加本文要记录的大概内容&#xff1a; 问题复现&#xff1a; import requestsheaders {"Accept": &quo…

IntelliJ IDEA使用技巧与插件推荐

IntelliJ IDEA是一款功能强大的集成开发环境&#xff08;IDE&#xff09;&#xff0c;它提供了丰富的功能和工具&#xff0c;帮助开发者提高编码效率。本文将介绍一些IntelliJ IDEA的使用技巧以及实用的插件推荐。 一、IntelliJ IDEA使用技巧 快捷键操作 IntelliJ IDEA支持大量…

Excel:vba实现插入图片

实现的效果&#xff1a; 实现的代码&#xff1a; Sub InsertImageNamesAndPictures()Dim PicPath As StringDim PicName As StringDim PicFullPath As StringDim RowNum As IntegerDim Pic As ObjectDim Name As String 防止表格里面有脏数据Cells.Clear 遍历工作表中的每个图…

JVM 运行时数据区

JVM整体架构 可以分为三层&#xff1a; 1 JVM外部&#xff0c;从源文件到Class文件&#xff0c;再装载到JVM 2 JVM运行时数据区&#xff0c;相当于就是避风港、运行的大后方。给执行程序提供后勤。 3 执行引擎层。和运行时数据区交互&#xff0c;完成执行任务。 运行时数据…