Postgresql日志系统的实现(十一)

2.2      CreateCheckPoint如何处理日志?

1.调用XLogInsert对应的日志记录(即:当前checkpoint的信息,注意,checkpoint的信息也写入到xlog中,但是checkpoint的信息不需要系统崩溃后重启做redo操作。既然不需要,为何要记载入xlog)写入日志缓冲区

2.调用XLogFlush,将之前的日志记录从日志缓冲区中写入磁盘。

3.调用MoveOfflineLogs,重用那些可重用的日志段。

       a)    遍历文件夹pg_xlog中的文件

i.判断该文件是否是日志文件(根据文件名的长度是否是24位,并且文件名的内容是否由16进制表示来判断)且该文件的段在最近一次CheckPoint的日志段之前,如果不是,跳到a,遍历下一个文件。

ii.判断该文件是否已完成归档(根据archive_status目录下是否有该文件对应的ready文件或done文件判断),如果在非归档状态下,默认为是。如果不是的话,跳到a,遍历下一个文件

iii.判断该文件是否可重用,(所谓该文件可重用是指当前segid之后2*CheckPointSegments + 1个段的日志文件是否都已产生),如果存在有些日志段没有产生,那么将这个文件改名成以后的日志段名。否则,删除该文件。

iv.删除该文件对应的“.ready”和“.done”文件

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值