登录
/
注册
首页
论坛
其它
首页
科技
业界
安全
程序
广播
Follow
关于
每日签到
每天签到奖励2圆-6圆
发帖说明
VIP申请
登录
/
注册
账号
自动登录
找回密码
密码
登录
立即注册
搜索
搜索
关闭
CSDN热搜
程序园
精品问答
技术交流
资源下载
本版
帖子
用户
软件
问答
教程
代码
写记录
写博客
VIP申请
VIP网盘
网盘
联系我们
每日签到
道具
勋章
任务
设置
我的收藏
退出
腾讯QQ
微信登录
返回列表
首页
›
业界区
›
安全
›
PostgreSQL中checkpoint的作用和工作原理
PostgreSQL中checkpoint的作用和工作原理
[ 复制链接 ]
跟尴
2025-6-10 15:58:42
###checkpoint的作用
将脏页写入磁盘,避免数据库实例重启之后需要从WAL中恢复大量的数据而增加数据库恢复时间
###checkpoints的触发时机
1,手动CHECKPOINT命令;
2,pg_basebackup,CREATE DATABASE,或pg_ctl stop|restart;
3,定期执行的checkpoint,也即每隔checkpoint_timeout定时执行的,默认值为300秒
4,自上一个检查点以来生成了已配置的最大WAL文件数量,
属于被动checkpoint
。
###checkpoint触发时的执行步骤
1,识别共享缓冲区中的所有脏页(已修改的页);
2,将所有这些缓冲区写入磁盘(或更确切地说,写入文件系统缓存);
3,调用fsync()将所有修改后的文件刷新到磁盘(数据文件)。
###checkpoint的执行时间参数
checkpoint执行时主要是物理IO操作,这是一个比较耗时的操作,PostgreSQL尽可能在checkpoint_timeout*checkpoint_completion_target这个时间范围内完成物理IO操作。
也就是说,只要在规定的时间内完成本次物理IO操作即可,checkpoint_completion_target是一个介于0到1的一个比例,默认值是0.5,那么在 checkpoint 操作的
前 50% 时间内
,PostgreSQL 会尽量将缓冲区的脏页写入磁盘,这样避免了在 checkpoint 结束时产生突发的 I/O 高峰。
checkpoint相关的系统表字段的含义,来自于:https://www.cnblogs.com/abclife/p/14573514.html
=#select * from pg_stat_bgwriter;
-[ RECORD 1 ]---------+-----------------------------
checkpoints_timed | 15462 #计划检查点的发生次数,这种检查点是checkpoint_timeout参数规定的超时达到后系统启动的checkpoint;
checkpoints_req | 148 #被动checkpoint,非计划检查点的次数,包含手动的检查点、xlog(redo日志)检查点(指当某些数据库预定的阈值达到时启动的检查点,比如WAL已经超出了max_wal_size或者checkpoint_segments,也会触发xlog ckpt)
checkpoint_write_time | 2130524730 #检查点写入的总时长
checkpoint_sync_time | 72082 #检查点同步文件的总时长
buffers_checkpoint | 174657791 #检查点清理的脏块
buffers_clean | 0 #bgwriter清理的脏块数量
maxwritten_clean | 0 #bgwriter清理脏块的时候达到bgwriter_lru_maxpages后终止写入批处理的次数,为了防止一次批量写入太大影响数据块IO性能,bgwriter每次都有写入的限制。不过这个参数的缺省值100太小,对于负载较高的数据库,需要加大;
buffers_backend | 24491898 #backend清理的脏块数量
buffers_backend_fsync | 2 #backend被迫自己调用fsync来同步数据的计数,如果这个计数器不为零,说明当时的fsync队列已经满了,存储子系统肯定出现了性能问题;
buffers_alloc | 51275374 #buffer分配的次数
stats_reset | 2021-01-29 14:41:48.97647+08 #上一次RESET这些统计值的时间
=#
复制代码
参考:
https://guobo507.github.io/2020/basic-tuning-of-checkpoint/
https://www.cnblogs.com/abclife/p/14573514.html
https://cloud.tencent.com.cn/developer/article/1882199
来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
PostgreSQL
checkpoint
作用
工作
原理
相关帖子
UniApp自定义Android基座原理及流程
P2P打洞原理与实践系统化入门教程
【URP】[平面阴影]原理与实现
Mysql事务原理与优化
工作需求记录:处理用户隐私数据,AES对称加密工具类,Crypto库及其使用
工作需求记录:处理用户隐私数据,AES对称加密工具类,Crypto库及其使用
什么样的工作用Coze可以加速?(分享个人简历与岗位匹配度分析工具案例)
PostgreSQL三种关闭方式的区别
PostgreSQL中的work_mem参数
计算机组成原理—运算方式
vip免费申请,1年只需15美金$
回复
使用道具
举报
提升卡
置顶卡
沉默卡
喧嚣卡
变色卡
千斤顶
照妖镜
相关推荐
业界
UniApp自定义Android基座原理及流程
0
395
翁谌缜
2025-08-30
业界
P2P打洞原理与实践系统化入门教程
0
299
国瑾瑶
2025-08-30
业界
【URP】[平面阴影]原理与实现
0
864
语樊偿
2025-09-02
安全
Mysql事务原理与优化
0
1016
啸妹回
2025-09-02
安全
工作需求记录:处理用户隐私数据,AES对称加密工具类,Crypto库及其使用
0
656
冷晓晴
2025-09-04
安全
工作需求记录:处理用户隐私数据,AES对称加密工具类,Crypto库及其使用
0
353
二艰糖
2025-09-04
安全
什么样的工作用Coze可以加速?(分享个人简历与岗位匹配度分析工具案例)
0
192
静轾
2025-09-05
业界
PostgreSQL三种关闭方式的区别
0
602
侧胥咽
2025-09-06
安全
PostgreSQL中的work_mem参数
0
670
毡轩
2025-09-08
安全
计算机组成原理—运算方式
0
868
旁拮猾
2025-09-08
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
立即注册
回复
本版积分规则
回帖并转播
回帖后跳转到最后一页
浏览过的版块
业界
签约作者
程序园优秀签约作者
发帖
跟尴
2025-6-10 15:58:42
关注
0
粉丝关注
14
主题发布
板块介绍填写区域,请于后台编辑
财富榜{圆}
敖可
9984
杭环
9988
凶契帽
9988
4
氛疵
9988
5
黎瑞芝
9988
6
猷咎
9986
7
里豳朝
9986
8
肿圬后
9986
9
蝓俟佐
9984
10
虽裘侪
9984
查看更多