PG数据库checkpoint浅析

44 篇文章 183 订阅 ¥9.90 ¥99.00

相关问题引入

这里列举几个问题,由此引发我们对 checkpoint 相关机制的思考:

  1. 我们日常操作Postgresql 数据库时,很多操作都会触发数据库的 checkpoint 事务(例如启动、关闭数据库,数据库超级管理员显式地执行 checkpoint 命令等)。那到底都有哪些行为或事件会触发 checkpoint 呢?

  2. 有些人使用 Postgresql 数据库时,可能会在数据库的 log 日志中发现类似于如下提示:

    • (英文环境)checkpoints are occurring too frequently…
    • (中文环境)检查点事件发生过于频繁…

    那为什么会出现这样的现象呢,发生这样的现象后,我们可以选择如何排查、解决此类问题?

checkpoint 相关机制

下文简单总结了发生 checkpoint 的时机:

1. 检查点发生的时机

首先,checkpoint 有如下分类:

#define CHECKPOINT_IS_SHUTDOWN	0x0001	/* Checkpoint is for shutdown */
#define CHECKPOINT_END_OF_RECOVERY	0x0002	/* Like shutdown checkpoint, but
											 * issued at end of WAL recovery */
#define CHECKPOINT_IMMEDIATE	0x0004	/* Do it without delays */
#define CHECKPOINT_FORCE		0x0008	/* Force even if no activity */
#define CHECKPOINT_FLUSH_ALL	0x0
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lg4546

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值