时间:2021-07-01 10:21:17 帮助过:27人阅读
原文链接:https://stackoverflow.com/questions/41932735/sql-server-instance-recovery
关于Oracle的实例恢复参考之前的博文:http://www.cnblogs.com/leohahah/p/6973600.html
首先看一下SQL Server中事务日志的作用:
在SQL Server数据库中,事务日志用于记录事务在Buffer Cache中的做的页更改。
当我们更新一些数据时,数据库会把相关数据页的前镜像和后镜像都记录在事务日志中,并为每个事务生成一个唯一的LSN(log seq number),在检查点发生时SQL Server确保检查点LSN之前的脏块被全部写入到磁盘。因此SQL Server的事务日志兼有redo和undo的作用。
但是,如果我们的数据库被强制关闭或者服务器异常掉电重启,数据库就将处于非一致性的状态(没业务的库除外),这意味检查点之后的所有事务(无论是提交还是未提交的),都出现了异常,提交的事务可能脏块未被写入磁盘,未提交的长事务可能有一部分脏块已经被写入到磁盘,数据库必须处于一致状态才能被正常打开,因此此时必须进行实例恢复。
SQL Server的实例恢复分两个阶段:
1.前滚
此阶段只处理已提交的事务,根据boot page中记录的检查点和事务日志的记载,SQL Server重构检查点之后的内存脏块并按正常机制提交已提交事务的脏块。
对未提交事务的脏块暂时不做操作。
2.回滚
此阶段处理未提交的事务,SQL Server根据事务日志中记载的更改块前镜像,去覆盖硬盘上那些未提交事务涉及的数据块。
总结一下:
1)实例恢复的目的:
2)实例崩溃之前:
3)实例恢复阶段:
在以上的介绍中我们提到了boot page,那么什么是boot page呢?
每个数据库都会有一个记录数据库重要信息的页,只有一页一般是 PRIMARY filegroup的第9个页。我们可以使用如下命令查看这一页的信息:
DBCC TRACEON (3604);
go
DBCC PAGE (‘test‘,1,9,0)
go
关于DBCC PAGE的用法这里解释一下:
dbcc page ( {‘dbname‘ | dbid}, filenum, pagenum [, printopt={0|1|2|3} ])
The printopt parameter has the following meanings:
0 - print just the page header
1 - page header plus per-row hex dumps and a dump of the page slot array (unless its a page that doesn‘t have one, like allocation bitmaps)
2 - page header plus whole page hex dump
3 - page header plus detailed per-row interpretation
检查点LSN被记录在boot page中,这是实例恢复的起点,如果这个page无法被访问,那么数据库就不能被附加,打开,或者做其他任何操作。检查点LSN只会被记录在bootpage中,因此这是一个对于实例恢复来说不可或缺的页。
对于SQL Server中检查点的解释:
当检查点发生时,无论这个检查点是如何触发的(手动执行检查点命令,或者数据库执行差异差异备份,或者数据库自动生成的检查点),数据库都会做以下操作:
SQL Server的实例恢复解析
标签:ima 崩溃 内存 logs 有序性 也会 数据 class ceo