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

http://database.51cto.com  2010-09-13 14:45  我爱菊花  博客园  我要评论(0)
  • 摘要:我们今天要讨论的话题是数据库快照。在SQL Server 2008高可用性中,快照是一项很重要的内容,可以提供至关重要的线索。
  • 标签:SQL Server 2008
  • 限时报名参加“甲骨文全球大会·2010·北京”及“JavaOne和甲骨文开发者大会2010”
一: 简介
数据库快照是数据库(源数据库)的只读、静态视图。多个快照可以位于一个源数据库中,并且可以作为数据库始终驻留在同一服务器实例上。创建快照时,每个数据库快照在事务上与源数据库一致。在被数据库所有者显式删除之前,快照始终存在。
快照可用于报表。另外,如果源数据库出现用户错误,还可将源数据库恢复到创建快照时的状态。丢失的数据仅限于创建快照后数据库更新的数据。
运行原理: 数据库快照在数据页级运行。在第一次修改源数据库页之前,先将原始页从源数据库复制到快照。此过程称为“写入时复制操作”。快照将存储原始页,保留它们在创建快照时的数据记录。对已修改页中的记录进行后续更新不会影响快照的内容。对要进行第一次修改的每一页重复此过程。这样,快照将保留自创建快照后经修改的所有数据记录的原始页。
注:只有 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. 创建数据库快照
语法示例:
  1. CREATE DATABASE AdventureWorks2008_dbss1800 ON
  2. NAME = AdventureWorks2008_Data, FILENAME = ‘D:\DATA\AdventureWorks2008_data_1800.ss' )
  3. AS SNAPSHOT OF AdventureWorks2008;
  4. .Snapshot Name: AdventureWorks2008_dbss1800
  5. .NAME: source database data file name
  6. .FILENAME: snapshot sparse file name
3. 删掉数据库快照
  1. DROP DATABASE AdventureWorks2008_dbss1800
四:数据库快照的限制
1. 对源数据库的限制
不能对数据库进行删除、分离或还原。
源数据库的性能受到影响。由于每次更新页时都会对快照执行“写入时复制”操作,导致源数据库上的 I/O 增加。
不能从源数据库或任何快照中删除文件。
源数据库必须处于联机状态,除非该数据库在数据库镜像会话中是镜像数据库。
不能将源数据库配置为可缩放共享数据库。
若要在镜像数据库中创建数据库快照,数据库必须处于同步镜像状态。
2. 数据库快照的限制
数据库快照必须与源数据库在相同的服务器实例上创建和保留。
始终对整个数据库拍摄数据库快照。
数据库快照与源数据库相关。因此,使用数据库快照还原数据库不能代替备份和还原策略。严格按计划执行备份仍然至关重要。如果必须将源数据库还原到创建数据库快照的时间点,请实施允许您执行该操作的备份策略。
当将源数据库中更新的页强制压入快照时,如果快照用尽磁盘空间或者遇到其他错误,则该快照将成为可疑快照并且必须将其删除。
快照为只读。
禁止对 model 数据库、master 数据库和 tempdb 数据库创建快照。
不能从数据库快照中删除文件。
不能备份或还原数据库快照。
不能附加或分离数据库快照。
注:更多的限制请参照MSDN。
四:总结
数据库快照只是提供数据恢复的一种方式,在遇到灾难发生时, 数据可以恢复到创建快照的那个时间点。恢复操作可以恢复最近出现的严重用户错误,如删除表等。不能代替完整的备份还原策略。
原文标题:SQL Server 2008高可用性(High Availability)简介(2)—Database Snapshots
链接:http://www.cnblogs.com/changbluesky/archive/2010/09/08/1821318.html
【编辑推荐】
  1. SQL Server 2000删除实战演习
  2. SQL Server存储过程的命名标准如何进行?
  3. 卸载SQL Server 2005组件的正确顺序
  4. 对SQL Server字符串数据类型的具体描述
  5. SQL Server数据类型的种类与应用
【责任编辑:彭凡 TEL:(010)68476606】

SQL Server 数据库

0

分享

微博 QQ 微信

收藏

上一篇: 一部合格的手机是怎么生产出来的... 下一篇:八种方式减少程序开发中的BUG
51bom

492篇文章,19W+人气,0粉丝

转载于:https://blog.51cto.com/2189440bop58/409872

SQL Server 2008高可用性系列:数据库快照相关推荐

  1. 黄聪:SQL server 2005高可用性之----数据库镜像

    SQL server 2005高可用性之数据库镜像,是SQL server 2005的新技术之一,是一种基于软件的高可用性解决方案,可以对不同服务器或同一服务器不同实例之间的数据库实验无数据延迟,自动 ...

  2. 实验二:SQL server 2005高可用性之----数据库镜像

    如转载,请注明出处:http://blog.csdn.net/robinson_0612/archive/2009/11/04/4769060.aspx SQL server 2005高可用性之数据库 ...

  3. Sql Server 2008 实现不同数据库-表实时同步 本地发布/订阅

    SQL server 不同数据库之间的表实时同步 图片大部分来自Sql Server 2008 实现不同数据库-表实时同步 本地发布/订阅 - 简书 有做适当的内容增加解释. 本地发布 1.新建发布 ...

  4. 基于Sql Server 2008的分布式数据库的实践(一)

    原文 基于Sql Server 2008的分布式数据库的实践(一) 配置Sql Server 2008(Win7) 1.打开SQL server2012,使用windows身份登录 2.登录后,右键选 ...

  5. 基于Sql Server 2008的分布式数据库的实践(五)

    基于Sql Server 2008的分布式数据库的实践(五) 原文 基于Sql Server 2008的分布式数据库的实践(五) 程序设计 ------------------------------ ...

  6. 基于Sql Server 2008的分布式数据库的实践(三)

    原文 基于Sql Server 2008的分布式数据库的实践(三) 配置PHP 1.打开PHP配置文件,找到extension=php_mssql.dll,将前面的注释符号去掉 2.找到mssql.s ...

  7. php删除sql server 2008,MSSQL_SQL Server2008 数据库误删除数据的恢复方法分享,SQL Server中误删除数据的恢复本 - phpStudy...

    SQL Server2008 数据库误删除数据的恢复方法分享 SQL Server中误删除数据的恢复本来不是件难事,从事务日志恢复即可.但是,这个恢复需要有两个前提条件: 1. 至少有一个误删除之前的 ...

  8. SQL Server 2008 R2 开启数据库远程连接

    今天要测试一个.net系统~因为配置的数据库是SQL Server~我就不得不安装SQL Server 2008 R2~现在我们就一起来看看SQL Server 2008 R2是如何打开远程连接端口1 ...

  9. 基于Sql Server 2008的分布式数据库的实践

    配置Sql Server 2008(Win7) 1.打开SQL server2012,使用windows身份登录 2.登录后,右键选择"属性".左侧选择"安全性" ...

最新文章

  1. java modbus通讯协议_物联通讯协议一(Modbus)
  2. 查询服务器上几张显卡命令
  3. placeholder的样式设置
  4. android属性动画作用范围,Android开发之动画效果浅析(一)
  5. 队列 一种数据结构(多线程利器)
  6. php tp5清空数据表并主键,tp5数据库——更新数据
  7. Prince2与PMP的区别
  8. Qt creator5.7 OpenCV249之高斯滤波(含源码下载)
  9. ZZULIOJ 1085: 求奇数的乘积(多实例测试)
  10. 七夕单日票房破5亿!创复工后单日票房新高
  11. vc++画线段的函数_专题:精选中考数学压轴题5道,函数综合,内含解题秘籍
  12. scrapy爬虫+echarts数据分析(安居客)
  13. (Activiti6.0.0)SpringProcessEngineConfiguration配置bean时属性注入不了,问题已经找到
  14. unix grep命令_Linux / UNIX中的Grep命令
  15. shutdown函数
  16. RDD创建及算子分类及应用
  17. apache如何加载系统环境变量_游学电子:windows10系统如何用cmd指令设置环境变量...
  18. 一线算法工程师总结:python常用数据挖掘算法PDF版
  19. 工厂流水线数据采集方案
  20. RGBA 图片格式转换 RGB 无损

热门文章

  1. 在.NET中实现彩色光标,动画光标和自定义光标
  2. Spring Mock单元测试
  3. Go在windows10 64位上安装过程
  4. CUDA Samples: green ball
  5. Windows 64位机上C/C++代码静态检查工具Logiscope RuleChecker的安装和使用
  6. eureka需要替换吗_iOS第三方库Eureka实现定制动画详解(二):万变不离其宗-Row组件...
  7. linux网卡设置adsl上网,Linux下设置ADSL自动拨号上网
  8. 5如何将表格的一行数据清空_微信公众号推文中如何自定义添加表格?
  9. c# redis hashid如何设置过期时间_Redis中Key过期策略amp;淘汰机制
  10. jQuery中的页面载入($()、ready(fn)、onload)