这篇文章主要介绍“PostgreSQL中checkpoint_completion_target参数对checkpoint调度的影响是什么”,在日常操作中,相信很多人在PostgreSQL中checkpoint_completion_target参数对checkpoint调度的影响是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”PostgreSQL中checkpoint_completion_target参数对checkpoint调度的影响是什么”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!PostgreSQL对checkpoint过程的调度,与数据库在运行过程中产生日志的大小和时间两个维度相关.日志
PostgreSQL源码中CalculateCheckpointSegments和IsCheckpointOnSchedule函数给出了checkpoint_completion_target参数对checkpoint调度的影响,在给出计算公式前,先行定义几个变量:
checkpoint进度progress:其中:
1.num_processed已处理的脏块数
2.num_to_scan总共需要处理的块数checkpoint启动后产生的日志相对允许最大日志量的比例:其中:
1.elapsed_xlogsize是指在checkpoint启动后产生的日志量(以MB为单位)
2.wal_segment_size默认为16MB
3.max_wal_size_mb是postgresql.conf配置文件中在满足以下条件时:在checkpointer进程会进行一定时间的休眠(100ms),以控制脏块刷盘(包括fsync)的进度.可以看出,上述条件的临界点是:现就此临界点对该公式进行变换,让checkpoint_completion_target放在等式的右边:由此可见,在其他变量一定的情况下,右边算式的值与checkpoint_completion_target成反比,checkpoint_completion_target越大该值越小,意味着checkpointer进程休眠的机会越多.时间
设elapsed_seconds=(now.tv_sec – ckpt_start_time + now.tv_usec / 1000000.0)表示过去消逝的时间
满足以下条件,checkpointer进度可休眠:右边表达式在其他变量一定的情况下,checkpoint_completion_target越大,则值越小,checkpointer可休眠的机会越大.到此,关于“PostgreSQL中che免费主机域名ckpoint_c免费主机域名ompletion_target参数对checkpoint调度的影响是什么”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注云技术网站,小编会继续努力为大家带来更多实用的文章!
这篇文章给大家分享的是有关Hanlp如何使用Bug的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Hanlp是最近学习的一个自然语言处理包,本篇文章将一些使用过程之中遇到的bug放到这里做一个备忘记录,有时间一并联系作者更免费主机域名…