论坛
潜水/灌水快乐,沉淀知识,认识更多同行。
ToB圈子
加入IT圈,遇到更多同好之人。
朋友圈
看朋友圈动态,了解ToB世界。
ToB门户
了解全球最新的ToB事件
博客
Blog
排行榜
Ranklist
文库
业界最专业的IT文库,上传资料也可以赚钱
下载
分享
Share
导读
Guide
相册
Album
记录
Doing
应用中心
搜索
本版
文章
帖子
ToB圈子
用户
免费入驻
产品入驻
解决方案入驻
公司入驻
案例入驻
登录
·
注册
只需一步,快速开始
账号登录
立即注册
找回密码
用户名
Email
自动登录
找回密码
密码
登录
立即注册
首页
找靠谱产品
找解决方案
找靠谱公司
找案例
找对的人
专家智库
悬赏任务
圈子
SAAS
IT评测·应用市场-qidao123.com技术社区
»
论坛
›
数据库
›
Oracle
›
PostgreSQL中checkpoint的作用和工作原理
PostgreSQL中checkpoint的作用和工作原理
刘俊凯
论坛元老
|
2024-10-31 19:04:56
|
显示全部楼层
|
阅读模式
楼主
主题
1812
|
帖子
1812
|
积分
5440
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要
登录
才可以下载或查看,没有账号?
立即注册
x
###checkpoint的作用
将脏页写入磁盘,避免数据库实例重启之后需要从WAL中规复大量的数据而增加数据库规复时间
###checkpoints的触发时机
1,手动CHECKPOINT下令;
2,pg_basebackup,CREATE DATABASE,或pg_ctl stop|restart;
3,定期执行的checkpoint,也即每隔checkpoint_timeout定时执行的
4,自上一个检查点以来天生了已设置的最大WAL文件数量,
属于被动checkpoint
。
###checkpoint触发时的执行步骤
1,辨认共享缓冲区中的所有脏页(已修改的页);
2,将所有这些缓冲区写入磁盘(或更确切地说,写入文件系统缓存);
3,调用fsync()将所有修改后的文件刷新到磁盘(数据文件)。
###checkpoint的执行时间参数
checkpoint执行时重要是物理IO操作,这是一个比较耗时的操作,PostgreSQL尽可能在checkpoint_timeout*checkpoint_completion_target这个时间范围内完成物理IO操作。
也就是说,只要在规定的时间内完成本次物理IO操作即可,checkpoint_completion_target是一个介于0到1的一个比例,乘以checkpoint_timeout得到checkpoint的最大执行时间
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
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复
使用道具
举报
0 个回复
倒序浏览
返回列表
快速回复
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
or
立即注册
本版积分规则
发表回复
回帖并转播
回帖后跳转到最后一页
发新帖
回复
刘俊凯
论坛元老
这个人很懒什么都没写!
楼主热帖
牛客SQL刷题第三趴——SQL大厂面试真题 ...
IDEA中集成Git操作以及关于Git中分支说 ...
MySQL ——select语句 一条龙服务 ...
SAP MM 使用两个STO实现免关税跨国公 ...
github上fork2.4k,star8.7k的这款状态 ...
Bug驱动开发探讨
袋鼠云春季生长大会最新议程来啦!4月2 ...
哈工大信息安全概论期末复习 ...
万字解析XML配置映射为BeanDefinition ...
事务
标签云
集成商
AI
运维
CIO
存储
服务器
登录参与点评抽奖加入IT实名职场社区
下次自动登录
忘记密码?点此找回!
登陆
新用户注册
用其它账号登录:
关闭
快速回复
返回顶部
返回列表