首页 / 数据库 / SQLServer / SQL Server中的CheckPoint
SQL Server中的CheckPoint2012-02-05 DrillChina 前面说到Recovery Interval可以控制SQL Server在内存中保留多少被修改的数据。其实我们有一个问题没有讲。那就是内存中被修改的数据写回到磁盘后,也就意味着磁盘中的数据版本和日志中的数据操作已经同步了。当然也就意味着如果这个时候系统崩溃了,SQL Server就不需要再恢复了。不过如果真的这个时候崩溃了,那么SQL Server怎么知道这些日志操作的数据已经写到磁盘了呢,所以SQL Server还有一个概念。这个概念就是CheckPoint。当SQL Server将一些被修改过的数据(术语叫Dirty Data)写回到磁盘后(这个操作的术语叫Flush),SQL Server会在日志中留下一个标记,以表示这个标记前的数据已经都被写到磁盘中了,而这个标记就叫做CheckPoint。因此我们可以这么说,CheckPoint代表着一次Flush操作。SQL Server会在以下情况下触发CheckPoint,也就是进行Flush:SQL Server在正常停止服务的时候日志中需要进行恢复的操作要花费超过Recovery Interval的时间时SQL Server可用内存不足的情况下管理员手动递交CHECKPOINT命令的时候当日志文件中的数据超过70%