第三章 crash recovery机制

server/2024/12/22 19:59:31/

第三章 crash recovery机制

一、为什么需要crash recovery

首先要从PostgreSQL的WAL说起。PG是面向磁盘的关系型数据库,数据的更新都需要在内存中完成,落盘才能保证持久化。普通硬盘的随机读写性能远小于顺序读写性能,而OLTP型业务大部分都是随机读写,若每次事务提交时都将内存中脏数据刷盘,势必会严重影响数据库系统性能。

WAL是数据页修改的日志,即修改后的数据镜像。通过WAL可以保证事务的原子性外,还可将随机写转变正顺序写,即每次事务提交时,将WAL持久化到磁盘,而脏数据页则由checkpoint进程和bgwriter进程异步刷写,从而降低磁盘IO对性能的影响。

因为脏数据是异步刷盘,所以当系统宕机或断电时,内存中脏数据可能还未持久化到磁盘,所以重启时为保证事务原子性及持久性,需要从WAL中将未持久化的数据恢复出来。

二、需要搞清楚的几个问题

1、数据库重启时怎么识别自己需要恢复,即上次关闭是非正常关闭

2、数据库从什么地方开始恢复,到什


http://www.ppmy.cn/server/40420.html

相关文章

下水道井盖多分类检测定位

下水道井盖识别,多分类,使用yolov5训练,采用一部分开源数据集和自建数据集。python pytorch opencv 深度学习#人工智能#深度学习#目标检测

力扣:300. 最长递增子序列(Java,动态规划)

目录 题目描述:示例 1:示例 2:代码实现: 题目描述: 给你一个整数数组 nums ,找到其中最长严格递增子序列的长度。 子序列 是由数组派生而来的序列,删除(或不删除)数组中…

C语言-STM32-定时器:定时器的输入捕获

定时器在嵌入式系统中常用于执行周期性任务、中断服务或测量时间间隔。输入输出捕获(Input Capture and Output Compare,简称ICP和OCM)是定时器的两种重要功能,用于处理与时间相关的事件。以下是它们的基本概念: 1、输…

网络安全(黑客)自学启蒙

当我们谈论网络安全时,我们正在讨论的是保护我们的在线空间,这是我们所有人的共享责任。网络安全涉及保护我们的信息,防止被未经授权的人访问、披露、破坏或修改。 一、网络安全的基本概念 网络安全是一种保护:它涉及保护我们的设…

Word应用:一键提取手写签名

1、将带有签名的图片插入到word文档中,裁剪出签名部分; 2、点击“格式-颜色”,选择“重新着色”中的“黑白50%”; 3、“格式-颜色”,设置透明色; 4、选择“文件”选项卡,选择打开“选项”,点击“…

WPF之页的使用

1,Page介绍。 Page直接从FrameworkElement中派生出来,WIndow从ContentControl中派生。 [Localizability(LocalizationCategory.Ignore)]public class Window : ContentControl, IWindowService{....} [ContentProperty("Content")]public class Page : Fr…

SSH简介:网络安全的守护者

SSH简介:网络安全的守护者 SSH(Secure Shell)是一种网络协议,用于在不安全的网络环境中提供安全的远程登录和其他网络服务。它使用加密技术来保护数据传输的完整性和机密性,防止潜在的窃听和篡改。SSH广泛应用于服务器…

如何开发一个Spring boot工程

引言 很多网站的后端都是基于Spring boot - mybatis进行开发的。 本文以此技术栈进行一个功能模块的开发 以最常见的注册功能为例 全部用最新的版本进行开发 工具 操作系统:Windows 10Java开发包:JDK 21项目管理工具:Maven 3.6.3项目开发…