我们已经讨论了各种不同的页,包括数据页GAM与SGAM页PFS页,还有IAM页。今天我们来看下差异变更页(Differential Change Map:DCM ),还有差异备份(differential backups)。

差异变更页(Differential Change Map:DCM:SQL Server使用差异变更页来跟踪自上次完全备份后修改过的区。DCM页在数据文件里是第6页。DCM页用来跟踪完全备份后修改过的区。DCM为每个跟踪的区使用每一位来记录。如果这个位是设置为1,那么自上一次完全备份后,这个区是被修改过了。如果这个位设置为0,那么自上一次完全备份后,这个区没有修改过。一个DCM页可以保存64000个左右区的信息。每隔511232页,DCM会重复一个。一个DCM页可以跟踪63904个区的变更信息。第2个DCM页会出现在第511238页。

差异备份通过读取DCM页来识别自上一次完全备份后,哪些区被修改过。这会大大减少差异备份扫描页数。差异备份花费的时间与自上次完全备份后修改的区数成正比,与整个数据库的大小无关。

我们新建一个空数据库,然后将其完全备份,并通过DBCC PAGE查看DCM页的信息。

 CREATE DATABASE DCMdb
GO
BACKUP DATABASE DCMdb TO DISK='D:\DCMdb.bak'
GO
DBCC TRACEON(3604)
DBCC PAGE('DCMdb',1,6,3)

可以看到,从第0页到第32页的区,自上次完全备份后,有发生改变。这并不是说,这32页每页都有改变。我们可以确定的说,至少有4页发生改变,一个区一个页。这可能是因为完全备份命令触发的内部表改变。

我们往表里插入点数据,再用DBCC PAGE命令看下DCM页的信息。

 SELECT * INTO DCMdb..SalesOrderDetail FROM AdventureWorks2008R2.sales.SalesOrderDetail
DBCC PAGE('DCMdb',1,6,3)

通过SELECT INTO我们往数据库里创建了新表,并往里面插入了数据,这会触发很多系统表的变更。结果我们看到自上次完全备份后,很多区标记为改变。一直到1:167页,这里的改变都是内部对象的修改。页从1:184至1:1679的改变,是因为我们SELECT INTO语句触发的。当我们进行差异备份时,SQL Server读取DCM页,这些变更页会在差异备份里做上标记。例如我们刚才提到的,页(1:0-1:24)在DCM页标记为改变页,实际可能只有有4个页发生改变,但在差异备份里,这32个页都会备份。
我们进行一个差异备份,并通过DBCC PAGE看看DCM页的信息。

 BACKUP DATABASE DCMdb TO DISK='D:\DCMdbifferential.bak' WITH DIFFERENTIAL

 DBCC PAGE('DCMdb',1,6,3)

可以看到差异备份不会改变DCM页的内容。

我们来计算下这个备份大小是否和DCM改变页的大小一致。

((32-0) + (56-48) + (88-72)  + (136-112) +(168-144)+(1680-184)  ) * 8=12800KB ,基本接近,这里的差距是文件头信息。

我们现在进行一次完整备份,再用DBCC PAGE看下DCM页的信息。

 BACKUP DATABASE DCMdb TO DISK='D:\DCMdb2.bak'
DBCC PAGE('DCMdb',1,6,3)

现在SQL Server清空了DCM页。所有页都被标记为未改变,除了4个分区1:0-1:32。这个备份将用来后续差异备份的基础。有个选项可以设置完全备份不影响现存的备份链。

 BACKUP DATABASE DCMdb TO DISK='D:\DCMdb2_Copy.bak' WITH COPY_ONLY

在这个情况下,SQL Server不会重设DCM页。DCMdb2.bak文件还是完全备份文件,并未后续差异备份做基础。这在一些你想完全备份又不想影响到备份链的时候可以用到。
小结一下:SQL Server通过DCM页跟踪分区改变信心。当进行差异备份时,SQL Server只备份DCM页里标记为改变的区。它帮助SQL Sever加速差异备份操作,通过不扫描所有的页看看有没有修改(或自上次完整备份有没有改变)。差异备份不会清空DCM页,它只备份从上次完全备份后发生改变的区。当进行完整备份时,SQL Server在DCM页重设位状态,标记它们为未改变。

参考文章:

http://www.sqlservercentral.com/blogs/practicalsqldba/2013/07/23/sql-server-understanding-differential-changes-map-dcm-and-differential-backups/

SQL Server存储(6/8) :理解DCM页的更多相关文章

  1. SQL Server :理解DCM页

    原文:SQL Server :理解DCM页 我们已经讨论了各种不同的页,包括数据页.GAM与SGAM页.PFS页,还有IAM页.今天我们来看下差异变更页(Differential Change Map ...

  2. SQL Server 存储(1/8):理解数据页结构

    我们都很清楚SQL Server用8KB 的页来存储数据,并且在SQL Server里磁盘 I/O 操作在页级执行.也就是说,SQL Server 读取或写入所有数据页.页有不同的类型,像数据页,GA ...

  3. SQL Server 存储(3/8):理解GAM和SGAM页

    我们知道SQL Server在8K 的页里存储数据.分区就是物理上连续的8个页.当我们创建一个数据库,数据文件会被逻辑分为页和区,当用户对象创建时,页会分配给它用来存储数据.GAM(Global Al ...

  4. SQL Server 存储(8/8):理解数据文件结构

    这段时间谈了很多页,现在我们可以看下这些页在数据文件里是如何组织的. 我们都已经知道,SQL Server把数据文件分成8k的页,页是IO的最小操作单位.SQL Server把数据文件里的第1页标记为 ...

  5. SQL SERVER存储引擎——04.数据

    4. SQL SERVER存储引擎之数据篇 (4.1)文件 (0)主数据文件.mdf初始文件大小至少为3MB,次要数据文件.ndf初始大小,同日志文件一样至少为512KB: (1)SQL SERVER ...

  6. SQL Server存储ntext截断问题

    SQL Server存储ntext截断问题   最近遇到一个问题:将大文本存储到数据库的时候,查询出来的文本却被截断了. 最后百度发现,作者提出 sql server management studi ...

  7. SQL Server 存储(5/8):理解IAM 页

    在以前的文章里,我们讨论了数据页,GAM和SGAM,还有PFS页.今天我们一起来讨论下索引分配映射(Index Allocation Map:IAM)页. 在SQL Server 2005和以后的版本 ...

  8. SQL Server存储(7/8) :理解BCM页

    今天我们来讨论下批量更改映射(Bulk Changed Map:BCM)页,还有大容量日志恢复模式( bulk logged recovery model )如何运作的. 批量更改映射(Bulk Ch ...

  9. SQL Server 存储(2/8):理解数据记录结构

    在SQL Server :理解数据页结构我们提到每条记录都有7 bytes的系统行开销,那这个7 bytes行开销到底是一个什么样的结构,我们一起来看下. 数据记录存储我们具体的数据,换句话说,它存在 ...

随机推荐

  1. javascript Xml兼容性随笔

    一.前言 (function (window) { if (!window.jasen) { window.jasen = {}; } if (!window.jasen.core) { window ...

  2. SQL入门经典(五) 之键和约束

    这一篇博客主要讲键的创建,约束的创建.修改对象和删除对象. 主键:主键是每行的唯一标识符,必须包含唯一值(因此不能为NULL).由于主键在关系中数据库的重要性,因此它是所有键和约束中最重要的.一个表最 ...

  3. 奇妙的动态代理:EF中返回的对象为什么序列化失败

    今天有如鹏的学生遇到一个问题:把一个对象保存到Session中(进程外Session)后,Web服务器重启,当从Session读取这个对象的时候报错,提示是一个“T_Users”后面跟着一大串数字的类 ...

  4. 开始VS 2012中LightSwitch系列的第3部分:我该选择哪一个屏幕模板

    [原文发表地址]  Beginning LightSwitch in VS 2012 Part 3: Screen Templates, Which One Do I Choose? [原文发表时间] ...

  5. SQL SERVER 内存学习系列(二)-DMV查看内存信息

    内存管理在SQL Server中有一个三级结构.底部是内存节点,这是最低级的分配器,用于SQL Server的内存.第二个层次是由内存Clerk组成,这是用来访问内存节点和缓存存储,缓存存储则用于缓存 ...

  6. Linux2:vi、ls、cd、pwd、mkdir、rm、mv、cp、cat、tail

    前言 从本篇文章开始,每篇文章将写10个Linux命令,个人的写作想法是: 1.常用的Linux命令,那些生僻的.不常用的就不写了 2.从实际考虑,只列出每个命令常见的用法和参数选项,有兴趣了解进一步 ...

  7. 示例篇-购物车的简单示例和自定义JS

    简介: 支持平台: Android4.0,iOS7.0,Windows 10, Windows 10 mobile 说明:主要是演示listview所在的ui和模板cell所在的ui之间数据的交互,点 ...

  8. JavaScript函数编程-Ramdajs

    在JavaScript语言世界,函数是第一等公民.JavaScript函数是继承自Function的对象,函数能作另一个函数的参数或者返回值使用,这便形成了我们常说的高阶函数(或称函数对象).这就构成 ...

  9. 译文---C#堆VS栈(Part Three)

    前言 在本系列的第一篇文章<C#堆栈对比(Part Two)>中,介绍了值类型和引用类型在参数传递时的不同,本文将讨论如何应用ICloneable接口实现去修复引在堆上的用变量所带来的问题 ...

  10. 4、CC2541芯片中级教程-OSAL操作系统(简单AT指令实现+IIC软件和硬件实现驱动MPU6050)

    本文根据一周CC2541笔记汇总得来—— 适合概览和知识快速索引—— 全部链接: 中级教程-OSAL操作系统\OSAL操作系统-实验01 OSAL初探 [插入]SourceInsight-工程建立方法 ...