阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

SQL Server的实例恢复解析

346次阅读
没有评论

共计 2348 个字符,预计需要花费 6 分钟才能阅读完成。

同 Oracle 一样,SQL Server 在非一致性关闭的时候也会进行实例恢复(Instance Recovery), 本文根据 stack overflow 的文章介绍一些 SQL Server 实例恢复的知识。

原文链接:https://stackoverflow.com/questions/41932735/sql-server-instance-recovery

关于 Oracle 的实例恢复参考之前的网址:http://www.linuxidc.com/Linux/2017-06/144601.htm

首先看一下 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)实例恢复的目的:

  • 将所有已提交事务的脏块写入磁盘。
  • 回滚未提交的事务。
  • 将检查点推进至已被写入磁盘的事务 LSN。

2)实例崩溃之前:

  • 一些已提交的事务被事务日志记录,但是脏块未被写入到磁盘
  • 一些未提交的长事务中的脏块已经被写入到磁盘
  • 一些未提交的事务,其日志还留在 log buffer 中未被写入到磁盘中的事务日志文件。

3)实例恢复阶段:

  • Log buffer 中所有未提交事务的日志在掉电时全部被清空。(已提交事务的日志默认被写入了磁盘事务日志文件)
  • 从 boot page 中识别出上一个检查点,作为实例恢复的起点。
  • 在前滚阶段,SQL Server 根据事务日志的记录对所有脏块进行重现。(无论是提交还是未提交的事务)然后将已提交事务的脏块写入磁盘,对未提交事务的脏块暂不作操作。
  • 在回滚阶段,SQL Server 根据事务日志中记载的前镜像对所有未提交的事务进行回滚。
  • 更新 boot page 中的检查点 LSN 和事务日志中的 LSN。

在以上的介绍中我们提到了 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 中检查点的解释:

当检查点发生时,无论这个检查点是如何触发的(手动执行检查点命令,或者数据库执行差异差异备份,或者数据库自动生成的检查点),数据库都会做以下操作:

  • 所有的脏块都被写入磁盘,无论事务是否已提交。
  • 在这些脏块被写入磁盘之前,所有关于这些脏块更改的事务日志也要被从 log buffer 中写入到磁盘,这样可以确保实例恢复的有效性和有序性,这个操作被称作 write-ahead logging(日志先写),日志被写入硬盘的操作是严格按时间序列化的,不可能以事务为单位来离散的写入到磁盘,因此某个脏块的写入磁盘操作,可能引发 log buffer 中一些之前的、与本脏块无关的事务日志也被写入磁盘。但这是有好处的,事务日志总是被越早写入磁盘越好。
  • 检查点的 LSN 会被记录到数据库 boot page 中的dbi_checkptLSN���域。
 

这里可以复习一些 Oracle 的检查点机制,也是 CKPT 进程触发 DBWR 写脏块,同时如果要写的脏块的 scn 大于 LGWR 的 scn,DBWR 也会触发 LGWR 把要写的脏块的相关 log buffer 写入 redo 文件中,与 SQL Server 日志先写的机制相似。

本文永久更新链接地址:http://www.linuxidc.com/Linux/2017-06/144602.htm

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-22发表,共计2348字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中

星哥玩云

星哥玩云
星哥玩云
分享互联网知识
用户数
4
文章数
19348
评论数
4
阅读量
7803665
文章搜索
热门文章
开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南

开发者必备神器:阿里云 Qoder CLI 全面解析与上手指南 大家好,我是星哥。之前介绍了腾讯云的 Code...
星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛 NAS-6:抖音视频同步工具,视频下载自动下载保存 前言 各位玩 NAS 的朋友好,我是星哥!...
云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板1Panel:小白轻松构建Web服务与面板加固指南

云服务器部署服务器面板 1Panel:小白轻松构建 Web 服务与面板加固指南 哈喽,我是星哥,经常有人问我不...
我把用了20年的360安全卫士卸载了

我把用了20年的360安全卫士卸载了

我把用了 20 年的 360 安全卫士卸载了 是的,正如标题你看到的。 原因 偷摸安装自家的软件 莫名其妙安装...
星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛 NAS-3:安装飞牛 NAS 后的很有必要的操作 前言 如果你已经有了飞牛 NAS 系统,之前...
阿里云CDN
阿里云CDN-提高用户访问的响应速度和成功率
随机文章
国产开源公众号AI知识库 Agent:突破未认证号限制,一键搞定自动回复,重构运营效率

国产开源公众号AI知识库 Agent:突破未认证号限制,一键搞定自动回复,重构运营效率

国产开源公众号 AI 知识库 Agent:突破未认证号限制,一键搞定自动回复,重构运营效率 大家好,我是星哥,...
再见zabbix!轻量级自建服务器监控神器在Linux 的完整部署指南

再见zabbix!轻量级自建服务器监控神器在Linux 的完整部署指南

再见 zabbix!轻量级自建服务器监控神器在 Linux 的完整部署指南 在日常运维中,服务器监控是绕不开的...
浏览器自动化工具!开源 AI 浏览器助手让你效率翻倍

浏览器自动化工具!开源 AI 浏览器助手让你效率翻倍

浏览器自动化工具!开源 AI 浏览器助手让你效率翻倍 前言 在 AI 自动化快速发展的当下,浏览器早已不再只是...
2025年11月28日-Cloudflare史诗级事故:一次配置失误,引爆全球宕机

2025年11月28日-Cloudflare史诗级事故:一次配置失误,引爆全球宕机

2025 年 11 月 28 日 -Cloudflare 史诗级事故: 一次配置失误,引爆全球宕机 前言 继今...
颠覆 AI 开发效率!开源工具一站式管控 30+大模型ApiKey,秘钥付费+负载均衡全搞定

颠覆 AI 开发效率!开源工具一站式管控 30+大模型ApiKey,秘钥付费+负载均衡全搞定

  颠覆 AI 开发效率!开源工具一站式管控 30+ 大模型 ApiKey,秘钥付费 + 负载均衡全...

免费图片视频管理工具让灵感库告别混乱

一言一句话
-「
手气不错
零成本上线!用 Hugging Face免费服务器+Docker 快速部署HertzBeat 监控平台

零成本上线!用 Hugging Face免费服务器+Docker 快速部署HertzBeat 监控平台

零成本上线!用 Hugging Face 免费服务器 +Docker 快速部署 HertzBeat 监控平台 ...
星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛 NAS-6:抖音视频同步工具,视频下载自动下载保存 前言 各位玩 NAS 的朋友好,我是星哥!...
12.2K Star 爆火!开源免费的 FileConverter:右键一键搞定音视频 / 图片 / 文档转换,告别多工具切换

12.2K Star 爆火!开源免费的 FileConverter:右键一键搞定音视频 / 图片 / 文档转换,告别多工具切换

12.2K Star 爆火!开源免费的 FileConverter:右键一键搞定音视频 / 图片 / 文档转换...
开发者福利:免费 .frii.site 子域名,一分钟申请即用

开发者福利:免费 .frii.site 子域名,一分钟申请即用

  开发者福利:免费 .frii.site 子域名,一分钟申请即用 前言 在学习 Web 开发、部署...
你的云服务器到底有多强?宝塔跑分告诉你

你的云服务器到底有多强?宝塔跑分告诉你

你的云服务器到底有多强?宝塔跑分告诉你 为什么要用宝塔跑分? 宝塔跑分其实就是对 CPU、内存、磁盘、IO 做...