PostgreSQL WAL 日志发展史 - pg7

文章目录

一、pg7.1 开天辟地

7.1 是 PostgreSQL 国际社区文档中提供详细资料的第一个版本,因为够完整也够简单,所以选择从 pg7.1 开始介绍

上图描述了 wal 日志的本职工作,PostgreSQL 在执行数据修改操作时,修改的数据在写入磁盘前要先将修改的内容写入 wal 日志,如此就可以不必时时地将共享缓存中的数据刷新到磁盘中,这样做的目的是以 wal 日志的顺序写入代替数据文件的随机写入来提升性能,如果数据库发生崩溃,可以从 wal 日志获取共享缓存中未写入磁盘的数据

1、WAL_BUFFERS

wal 日志缓冲区大小,用于减少磁盘 I/O 次数,提升性能

注意:

  • COMMIT 操作会触发一次对 wal_buffers 的强制刷盘,为了保证 ACID 中的 "D"(Durability,持久性),确保数据不会因系统崩溃而丢失,而且这还是一个同步(synchronous_commit)操作,会短暂阻塞事务直到 I/O 完成
  • XLOG_BLCKSZ(wal 日志基本单位)不是一个 GUC 参数,一般是编译数据库时通过 configure 命令指定,pg11(包含)之后,可以通过 initdb 命令指定

2、FSYNC

确保 wal 日志,或者其他数据文件安全写入磁盘

3、WAL_SYNC_METHOD

这个参数是对fsync参数的补全,它指定了保证数据写入持久化存储的方法。

4、COMMIT_DELAY & COMMIT_SIBLINGS

我们知道 COMMIT 操作会触发一次对 wal_buffers 的强制刷盘,期间 PostgreSQL 又做了一点小动作来提升性能:

  • commit_delay:事务提交后允许 wal 缓存延迟刷写的时间,这个延迟的目的是想等一下并行执行的兄弟事务,等兄弟事务完成提交后,一起将 wal 日志刷盘,如果兄弟事务超过 commit_delay 时间还未提交,那么当前进程就完成 wal 日志刷写
  • commit_siblings:当前事务做这个等待的条件,如果并行执行的兄弟事务小于 commit_siblings,那当前事务就不做等待了

可能文字描述比较难懂,举个例子:小明(事务)放学(提交)要打车回家(刷盘),他发现有顺路的其他班级的同学(兄弟事务)没有放学,就想等几个人一起平摊打车的费用,结果发现在上课的同学太少了(commit_siblings),就想等这么长时间省这么点钱不划算,就自己走了(刷磁);发现还在上课的同学很多,就想等一段时间(commit_delay)吧,等到这个时间长度带上下课的同学就走

注意:pg8.3 增加了可以定时刷写 wal 日志的进程 walwriter,该策略也因此改变

5、WAL_DEBUG

开启 wal debug 的参数,可以不用关注它

6、WAL_FILES

  • > 0:做检查点时会预先创建 wal_files 数量的 wal 段备用
  • = 0:会一个一个地创建 wal 段

注意:pg7.3 删除了该参数,改为另一种 wal 日志的预生成方法

7、CHECKPOINT_TIMEOUT

PostgreSQL 执行一次 checkpoint 的时间间隔,该参数跟 wal 关系没那么大,因为与下面的参数 checkpoint_segment 有相似的功能,都是触发 checopint 的时机,所以也写到了这里

8、CHECKPOINT_SEGMENT

PostgreSQL 执行一次 checkpoint 的 wal 段间隔,从上一次 checkpoint 开始,PostgreSQL 在写了一定数量的 wa l段后,会再次触发 checkpoint

二、pg7.3 改变 wal 预生成方式

此版本在 pg7.1 基础上做了微小的改变,主要是改变了预生成 wal 段的方法

checkpoint 时不再预生成 wal 段,改为了新的策略维护 wal 生成目录中的 wal 段:

  1. wal 段的数量原则上不超过 2 * checkpoint_segments + 1
  2. 一个流量高峰可能会导致 backend 极速生成 wal 日志,可能会将 wal 段数量增加到 2 * checkpoint_segments + 1 以上
  3. 做检查点时,如果 wal 段数量超限,会将超限的 wal 段删除, 如果 wal 段数量不超限,会将旧的 wal 段改名为将来的 wal 段。

因此参数 wal_files 不再使用,在该版本中被移除了,当然这个 wal 段的管理方式在 pg9.5 又有所变化

三、pg7.4 增加便利性 warning

此版本没有功能性的变化,只是增加了一个 warning 参数 checkpoint_warning

CHECKPOINT_WARNING

如果两次因为参数 checkpoint_segmet 产生的 checkpoint 的时间间隔小于 checkpoint_warning 值,会报一个 warning,用于提醒用户增大 checkpoint_segmet 值

相关推荐
惊讶的猫15 分钟前
mysql多表查询
数据库·mysql
可涵不会debug24 分钟前
Redis魔法学院——第四课:哈希(Hash)深度解析:Field-Value 层级结构、原子性操作与内部编码优化
数据库·redis·算法·缓存·哈希算法
学习不止,掉发不停26 分钟前
MySQL基础-DQL(四)
数据库·mysql
赵渝强老师29 分钟前
【赵渝强老师】国产金仓数据库的物理存储结构
数据库·postgresql·国产数据库
曹牧39 分钟前
Oracle闪回区配置与故障处理操作指南
数据库·oracle
无名-CODING1 小时前
Spring事务管理完全指南:从零到精通(上)
java·数据库·spring
fengxin_rou1 小时前
【黑马点评实战篇|第一篇:基于Redis实现登录】
java·开发语言·数据库·redis·缓存
我待_JAVA_如初恋1 小时前
Redis常用的数据类型之String
数据库·redis·缓存
@ chen1 小时前
MySQL 中的锁机制
数据库·mysql
Elastic 中国社区官方博客1 小时前
Elasticsearch:使用 Elastic Workflows 构建自动化
大数据·数据库·人工智能·elasticsearch·搜索引擎·自动化·全文检索