一: 简介
数据库快照是数据库(源数据库)的只读、静态视图。多个快照可以位于一个源数据库中,并且可以作为数据库始终驻留在同一服务器实例上。创建快照时,每个数据库快照在事务上与源数据库一致。在被数据库所有者显式删除之前,快照始终存在。
快照可用于报表。另外,如果源数据库出现用户错误,还可将源数据库恢复到创建快照时的状态。丢失的数据仅限于创建快照后数据库更新的数据。
运行原理: 数据库快照在数据页级运行。在第一次修改源数据库页之前,先将原始页从源数据库复制到快照。此过程称为“写入时复制操作”。快照将存储原始页,保留它们在创建快照时的数据记录。对已修改页中的记录进行后续更新不会影响快照的内容。对要进行第一次修改的每一页重复此过程。这样,快照将保留自创建快照后经修改的所有数据记录的原始页。
注:只有 SQL Server 2005 Enterprise Edition 和更高版本才提供数据库快照功能,所有恢复模式都支持数据库快照。
二:数据库快照的典型用法及工作方式
1. 数据库快照的典型用法:
提示:数据库快照与源数据库相关。因此,使用数据库快照还原数据库不能代替备份和还原策略。严格按计划执行备份仍然至关重要。如果必须将源数据库还原到创建数据库快照的时间点,请实施允许您执行该操作的备份策略。
2. 数据库快照的工作方式
了解快照中的稀疏文件:为了存储复制的原始页,快照使用一个或多个“稀疏文件”。最初,稀疏文件实质上是空文件,不包含用户数据并且未被分配存储用户数据的磁盘空间。随着源数据库中更新的页越来越多,文件的大小也不断增长。创建快照时,稀疏文件占用的磁盘空间很少。然而,由于数据库随着时间的推移不断更新,稀疏文件会增长为一个很大的文件。
快照的工作方式:
(1) 写操作
第一次写入时会把原始页页复制到快照。
(2) 读操作
无更新页之前的读过程
有更新页之后的读过程,可以看到快照读取的是创建快照时的那一页。
(3) 较多的读写之后
随着源数据库中更新的页越来越多,拷贝到快照中的页页越来越多,文件的大小也不断增长。
快照保存的是数据更新之前的那份拷贝,所以通过快照读取的数据是数据更新之前的那一份,数据丢失就可以恢复到创建快照的这个时间点。
三:应用实例
1. 快照的命名
创建数据库快照之前,考虑如何命名它们是非常重要的。每个数据库快照都需要一个唯一的数据库名称。为了便于管理,数据库快照的名称可以包含标识数据库的信息,例如:
如:
以6个小时为间隔(06:00-18:00之间)创建快照:
AdventureWorks2008_snapshot_0600
AdventureWorks2008_snapshot_1200
AdventureWorks2008_snapshot_1800
或者不太精确的命名:
AdventureWorks2008_snapshot_morning
AdventureWorks2008_snapshot_noon
AdventureWorks2008_snapshot_evening
2. 创建数据库快照
语法示例:
CREATE DATABASE AdventureWorks2008_dbss1800 ON ( NAME = AdventureWorks2008_Data, FILENAME = ‘D:\DATA\AdventureWorks2008_data_1800.ss' )
AS SNAPSHOT OF AdventureWorks2008;
.Snapshot Name: AdventureWorks2008_dbss1800
.NAME: source database data file name
.FILENAME: snapshot sparse file name
3. 删掉数据库快照
DROP DATABASE AdventureWorks2008_dbss1800
四:数据库快照的限制
1. 对源数据库的限制
2. 数据库快照的限制
注:更多的限制请参照MSDN。
四:总结
数据库快照只是提供数据恢复的一种方式,在遇到灾难发生时, 数据可以恢复到创建快照的那个时间点。恢复操作可以恢复最近出现的严重用户错误,如删除表等。不能代替完整的备份还原策略。