参考:http://msdn.microsoft.com/zh-cn/express/ms187054.aspx

SQL Server 2008 联机丛书(2009 年 1 月)
数据库快照的工作方式

数据库快照提供源数据库在创建快照时的只读、静态视图,不包含未提交的事务。由于 数据库引擎 在创建快照后运行恢复,因此未提交的事务在新近创建的数据库快照中回滚(数据库中的事务不受影响)。

数据库快照与源数据库相关。数据库快照必须与数据库在同一服务器实例上。此外,如果数据库因某种原因而不可用,则它的所有数据库快照也将不可用。

快照可用于报表。另外,如果源数据库出现用户错误,还可将源数据库恢复到创建快照时的状态。丢失的数据仅限于创建快照后数据库更新的数据。此外,在对数据库进行重大更改(例如,更改表的架构或结构)之前创建数据库快照也很有用。有关快照使用方式的详细信息,请参阅数据库快照的典型用法。

虽然不一定必须使用快照,但是了解其工作原理会有所帮助。数据库快照在数据页级运行。在第一次修改源数据库页之前,先将原始页从源数据库复制到快照。此过程称为“写入时复制操作”。快照将存储原始页,保留它们在创建快照时的数据记录。对已修改页中的记录进行后续更新不会影响快照的内容。对要进行第一次修改的每一页重复此过程。这样,快照将保留自创建快照后经修改的所有数据记录的原始页。

为了存储复制的原始页,快照使用一个或多个“稀疏文件”。最初,稀疏文件实质上是空文件,不包含用户数据并且未被分配存储用户数据的磁盘空间。随着源数据库中更新的页越来越多,文件的大小也不断增长。创建快照时,稀疏文件占用的磁盘空间很少。然而,由于数据库随着时间的推移不断更新,稀疏文件会增长为一个很大的文件。有关稀疏文件的详细信息,请参阅了解数据库快照中的稀疏文件大小。

下图说明了写入时复制操作。快照关系图中的浅灰色方框表示稀疏文件中尚未分配的潜在空间。收到源数据库中页的第一次更新时,数据库引擎将写入文件,操作系统向快照的稀疏文件分配空间并将原始页复制到该处。然后,数据库引擎更新源数据库中的页。下图说明了此类写入时复制操作。

重要提示:
由于数据库快照不是冗余存储,因此,它们不会防止磁盘出现错误或其他类型的损坏。为了保护数据库,非常有必要定期执行备份并测试还原计划。如果必须将源数据库还原到创建数据库快照的时间点,请实施允许您执行该操作的备份策略。
 对数据库快照的读操作

对于用户而言,数据库快照似乎始终保持不变,因为对数据库快照的读操作始终访问原始数据页,而与页驻留的位置无关。

如果未更新源数据库中的页,则对快照的读操作将从源数据库读取原始页。下图显示了对新创建的快照(因此其稀疏文件不包含页)的读操作。此读操作仅从源数据库读取。

更新页之后,对快照的读操作仍访问原始页,该原始页现在存储在稀疏文件中。下图说明了对访问源数据库中更新页的快照的读操作。此读操作从快照的稀疏文件中读取原始页。

 更新模式对数据库快照增长的影响

如果您的源数据库过大并且您担心磁盘空间使用量,则您应该在某个时候用新快照替换旧快照。快照理想的使用期限取决于其增长率以及可用于其稀疏文件的磁盘空间。快照所需的磁盘空间取决于在快照使用期限内源数据库中更新的不同页的数量。因此,如果大多数情况下更新重复更新的页的小子集,则随着时间的推移,增长率会降低,快照所需空间也会相对较小。相反,如果最终将所有原始页至少更新一次,则快照将会增长到源数据库的大小。如果磁盘将满,则快照会互相争用磁盘空间。如果磁盘驱动器已满,则无法将操作写入所有快照。

注意:
有关了解快照的实际大小和潜在大小的信息,请参阅了解数据库快照中的稀疏文件大小。

因此,在计划快照预计使用期限内所需空间量时,了解数据库的通常更新模式是很有用的。对于某些数据库,更新率可能相当稳定;例如,库存数据库可能每天都更新很多页,这对每天或每周替换旧快照非常有用。对于其他数据库,更新页的比例在业务周期内可能有所不同;例如,目录数据库可能通常每季度更新,会在其他时间偶尔更新;逻辑策略是在每季度更新前后创建快照。如果发生严重更新错误,允许还原更新前快照,而更新后快照用于报告下一季度的写入。

下图说明了两种相对的更新模式对快照大小的影响。更新模式 A 反映的是在快照使用期限内仅有 30% 的原始页更新的环境。更新模式 B 反映的是在快照使用期限内有 80% 的原始页更新的环境。

 数据库快照的元数据

对于数据库快照,数据库元数据包括 source_database_id 属性,该属性存储在 sys.databases 目录视图的列中。有关此属性的详细信息,请参阅 sys.databases (Transact-SQL)。

通常,数据库快照不公开自己的元数据,但会公开源数据库的元数据。例如,此元数据包括下列语句返回的数据:

USE <database_snapshot> SELECT * FROM sys.database_files 

其中,<database_snapshot> 是数据库快照的名称。

唯一的例外情况是当源数据库使用全文搜索或数据库镜像时,此时由于更改了快照元数据中的一些值,因此在快照上禁用了源数据库。

 请参阅

概念

了解数据库快照中的稀疏文件大小

其他资源

数据库快照

转载于:https://www.cnblogs.com/bluewind2879/archive/2009/03/04/1403300.html

数据库快照的工作方式相关推荐

  1. SQL Server 2008高可用性系列:数据库快照

    SQL Server 2008高可用性系列:数据库快照 http://database.51cto.com  2010-09-13 14:45  我爱菊花  博客园  我要评论(0) 摘要:我们今天要 ...

  2. 创建mysql数据库快照_数据库教程

    下面,容我来向大家介绍数据库学习内容,主要讲述的是SQL Server 2008高可用性系列之数据库快照.想了解的就来看看吧! 一:简介:数据库快照是一个数据库的只读副本,它是数据库所有数据的映射,由 ...

  3. 创建mysql数据库快照_创建数据库快照 (Transact-SQL)

    创建数据库快照 (Transact-SQL)Create a Database Snapshot (Transact-SQL) 08/10/2016 本文内容 适用于:Applies to: SQL ...

  4. SQL Server 2008 数据库快照

    数据库快照大家都知道吗?是不是有很多人没深入研究过呀.那么我们就来动手实验一下Sql Server 2008 的数据库快照功能吧! 首先,先来简单介绍一下数据库快照. 数据库快照其实也是一个数据库,不 ...

  5. 数据库索引的工作原理及其种类

    数据库索引的工作原理及其种类 数据库索引,是数据库管理系统中一个排序的数据结构,以协助快速查询.更新数据库表中数据.索引的实现通常使用B树及其变种B+树. 在数据之外,数据库系统还维护着满足特定查找算 ...

  6. SQL Server 2012笔记分享-49:理解数据库快照

    数据库快照是 SQL Server 数据库(源数据库)的只读静态视图. 自创建快照那刻起,数据库快照在事务上与源数据库一致. 数据库快照始终与其源数据库位于同一服务器实例上. 当源数据库更新时,数据库 ...

  7. oracle全库快照,Oracle数据库快照的使用

    正在看的ORACLE教程是:Oracle数据库快照的使用.oracle数据库的快照是一个表,它包含有对一个本地或远程数据库上一个或多个表或视图的查询的结果.正因为快照是一个主表的查询子集,使用快照可以 ...

  8. 计算机科学家Erik Meijer眼中的Hacker Way工作方式

    九月份在GoTo 2015大会上,和函数式编程.反应式异步编程有着紧密关联的,响当当的计算机科学家Erik Meijer在大会上与参会者分享了自己在接下来人生里最后几年的规划和打算,包括,他是如何看待 ...

  9. 如何启动和关闭oracle数据库,Oracle数据库启动和关闭方式总结

    Oracle数据库启动和关闭的方法很多,下面就为您详细介绍几种常用的Oracle数据库启动和关闭方式,供您参考学习之用. 一.几种Oracle数据库启动方式: 1.startup nomount 非安 ...

最新文章

  1. Express engine 学习笔记 - app.engine 的使用方法
  2. IntelliJ IDEA for Mac 在MacOS模式下的注释快捷键(Comment Shortcut)
  3. asp网站短信api服务器,asp短信接口源码 比较简单但也挺实用用的(两个写法)...
  4. 敏捷开发你必须知道的7件事
  5. HDU-3974 Assign the task 线段树 或 直接模拟多叉树 或 并查集 (三种方法)
  6. python 获取对象类型_python Class:获取对象类型
  7. 流媒体服务器- Wowza安装
  8. 创造生命奇迹的幸存者
  9. Cooling-Shrinking Attack: Blinding the Tracker with Imperceptible Noises
  10. Red Giant 安装及爆炸效果详解
  11. 信息学奥赛一本通:1096:数字统计
  12. 程序员写代码时你戴耳机是为了撩妹儿吗?感觉有点酷!
  13. python 中chr_python中chr
  14. C++学习45 流成员函数put输出单个字符 cin输入流详解 get()函数读入一个字符
  15. 什么是虚拟机,有什么用?
  16. 新媒体运营教程:直播间高转化活动如何策划!
  17. C++ 数组作为参数传入函数 int sum_arr(int arr[], int n)
  18. vs2017运行yolov4_VS2017运行YOLOv4
  19. 物体跟随鼠标移动——图片为gif格式
  20. GitHub使用方法(初级)

热门文章

  1. ROS学习笔记5(理解ROS节点)
  2. ROS学习笔记基础1(Ubuntu16.04安装ROS和依赖包)
  3. 3项目里面全局用less变量 cli vue_Vue实战14——抽离全局less变量与Vuex持久化、多模块构建...
  4. python网络爬虫的流程图_基于Python的网络爬虫的设计与实现
  5. Fiddler抓包详解
  6. Yearn已部署新YFI策略Brownie Mix
  7. Axure高保真学校后台管理作品管理教师管理资源审核学生管理家长管理权限管理资源管理web端后台模板管理教师审核统计分析教育后台管理系统学校后台管理系统校园后台管理系统
  8. 【学习总结】Git学习-参考廖雪峰老师教程三-创建版本库
  9. ”0元中标的商业逻辑“ -- 如何更好防范项目风险(北京软件造价评估技术创新联盟:李培圣)...
  10. java 16 - 15 集合嵌套存储和遍历元素