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”文件
本文介绍CreateCheckPoint过程中的日志处理步骤:通过XLogInsert记录checkpoint信息,使用XLogFlush将日志同步到磁盘,最后通过MoveOfflineLogs重用可重用的日志段。
954

被折叠的 条评论
为什么被折叠?



