数据库快照:是数据库某一时间点的视图,快照涉及最初目的是为了报表服务,快照还可以和镜像结合来达到读写分离的目的

数据库快照:是sqlserver数据库的只读静态视图
快照的作用:
1 提供了一个静态的视图来为报表服务
2 可以利用数据库快照来恢复数据库,相比备份来说,这个速度大大提高
3 和数据库镜像结合,提供读写分离
4 作为测试环境或则会数据变更前的备份,比如我要大批量删除或者导入数据前,或是将数据提供给测试人员进行测试前,做有一个快照,如果出现问题,则可以利用快照恢复到快照建立时候的状态

快照原理:与备份数据库复制整个数据库不同,快照并不复制这个数据库的页,而是仅仅复制在快照建立时间点之后改变的页,因此:当利用快照进行数据库恢复时,也仅仅将那些做了改变的页恢复到源数据库,这个速度大大提高

注意:源数据库建立快照会给IO增加负担

写入时复制:
快照数据库的文件基于稀疏文件,稀疏文件:是NTFS文件系统的一项特性,指文件中出现大量0的数据,这些数据用处不大,却占用磁盘空间,因此NTFS对此进行了优化,利用算法将这个文件进行压缩,因此当稀疏文件被创建时,刚打开很小,虽然逻辑上占了二三十M空间,但文件实际就是100多kb
当快照创建后,随着对源数据库的改变逐渐增多,稀疏文件也会慢慢增长

通常:当稀疏文件增长到源数据库文件大小的 30%时,就应该考虑重建快照了
稀疏文件的写入:利用了微软的写入时复制技术:意思是在复制一个对象的时候并不是真正把对象复制到另一个位置,而是在新的对象中映射一个指针,指向原对象的位置,这样当对新对象执行读操作时,直接指向源对象,而在对新的对象执行写操作时候,将改变部分对象的指针指向到新的地址中,并修改映射表到新的位置中

使用快照的法律:

1 当使用快照进行恢复数据库时,首先要删除其他快照
2 快照在创建时的时间点上没有commit的数据不会被计入快照
3 快照是快照整个数据库,而不是数据库的某一部分
4 快照是只读的,所以不能对快照进行任何更改,即使是想加一个让报表跑的更快的索引
5在利用快照恢复数据库时,快照和源数据库都不可用
6快照和源数据必须在同一个实例上
7快照上不能存在全文索引
8当磁盘不能满足快照的增长的时,快照数据库会被设置为suspect状态

快照只能通过sql语句创建,在创建之前,首先要知道数据库分部在哪几个文件中
可以使用这个命令查看:EXEC sp_helpdb Yip_20160322
因为快照需要对每一个文件进行 copy-on-writing

--创建数据库快照
CREATE DATABASE snap_Yip_20160322
ON
(
NAME = Yip_20160322,FILENAME = 'D:\SqlTest\snap_Yip_20160322.snap'
)
AS SNAPSHOT OF Yip_20160322
go

如果源数据库分部在多个mdf文件,则将每个用括号括起来,用逗号分隔

执行完了之后会在sqlserver中看到 有一个文件夹叫:

DATABASE Snapshots

点开之后就可以看到刚才新创建的快照

快照数据库文件和源数据库文件没啥不同,仅仅快照数据库文件是稀疏文件

删除快照数据库和删除普通数据库一样 使用 drop database 快照数据库名

--利用快照恢复数据库:

USE MASTER
RESTORE DATABASE Yipong_20160322 FROM DATABASE_SNAPSHOT = 'snap_Yipong_20160322'
go

注意:

1 快照数据库的安全设置继承自源数据库的安全设置,也就是说能访问源数据库的用户或者角色也能访问快照数据库,因为快照数据库是只读的,所以无论任何角色或者人都无法修改快照数据库

2 由于快照会拖累数据库性能,所以数据库不宜存在过多快照

sqlserver 关于快照的更多相关文章

  1. SqlServer代理执行[分发清除: distribution] 无法删除快照文件

    每天偶尔检查数据库作业是否失败,发现有错误 select top 10 job_id,run_date,run_time,run_duration,step_name,message from  ms ...

  2. sqlserver快照,启用基于行版本控制的隔离级别

    在sqlserver标准的已提交读(read committed)隔离级别下,读写操作相互阻塞.未提交读(read uncommitted)虽然不会有这种阻塞,但是读操作可能会读到脏数据,这是大部分用 ...

  3. Sqlserver 快照

    最近,开发系统使用SqlServer2008 R2,但是由于系统数据压力的增加,准备增加一个和正式数据库同步的库,用来供接口和报表使用,所以开始对SqlServer里面的一些技术开始研究,第一篇先来研 ...

  4. sqlserver数据库创建快照发布遇到的错误:对路径“XXXX”访问被拒绝

    在创建了一个sqlserver数据库的发布后,显示创建成功,但当查看快照代理状态时,显示“对路径‘XXXX’访问被拒绝”,这一错误导致订阅无法实现.然后网上有一方案帮忙解决了,主要有以下操作: 1)在 ...

  5. sqlserver同步后在不重新初始化快照的情况下新增表

           在已有事务复制中,时长需要新增表.索引,这些变更时不会同步到从库中.如果采用默认的设置,每次都需要重新初始化快照,从库重新应用快照和未执行的同步命令,这显然是无法在线上实践的方法.另一种 ...

  6. SQLServer Agent执行[分发清除: distribution] 无法删除快照文件

    由于之前创建的发布订阅造成严重的性能压力,症状表现为发布订阅表查询产生CMEMTHREAD  suspend等待,由于开发配置每隔十分钟会产生大量的SQLCOMMAND(create table,cr ...

  7. SQLServer之创建数据库快照

    创建数据库快照注意事项 语法:set transaction isolation level snapshot; 指定事务中任何语句读取的数据都将是在事务开始时便存在的数据的事务上一致的版本. 事务只 ...

  8. sqlserver配置允许快照隔离

    ALTER DATABASE TustenaOS SET ALLOW_SNAPSHOT_ISOLATION ON

  9. SQLServer 数据库镜像+复制方案

    目标: 主机做了Mirror和Replication,当主机出现问题时,Replication和Mirror实现自动的故障转移(Mirror 和Replication都切换到备机,而当主机 重新启动后 ...

随机推荐

  1. 推荐十款非常优秀的 HTML5 在线设计工具

    网络有很多优秀的设计和开发工具可能大家都不知道,因此这篇文章就向设计师推荐十款优秀 HTML5 在线工具,这些工具能够帮助设计师们设计出更有创意的作品.随着 HTML5 技术的不断成熟,网络上涌现出越 ...

  2. IOC使用Unity 实现依赖注入

    转自:http://www.cnblogs.com/techborther/archive/2012/01/06/2313498.html http://www.cnblogs.com/xishuai ...

  3. 虚拟机VMware里 windows server 2003 扩充C盘方法

    你会经常用windows server 2003 吗?应该不会吧,有时一些东西必须装在windows server 2003 上才能用,所以 用虚拟机把,好,装在虚拟机上,8G的C盘够你用吗,一个稍微 ...

  4. MEF 编程指南(六):导出和元数据

    声明导出解释了部件导出服务的基础知识和价值观(Values).有时候出于种种原因,导出关联信息是非常必要的.通常,用于解释关于功能公共契约的具体实现.允许导入满足约束要求的导出,或者导入所有可用的实现 ...

  5. MATLAB新手教程

    MATLAB新手教程   .MATLAB的基本知识 1-1.基本运算与函数    在MATLAB下进行基本数学运算,仅仅需将运算式直接打入提示号(>>)之後,并按入Enter键就可以.比如 ...

  6. Asp.net MVC @Html.DisplayNameFor中文乱码解决办法

    这是utf8的问题,vs2015默设要用utf8编码,以前的gb2312皆会产生乱码 这问题还是会继续发生,因为常会复制旧程序档进新方案.它会出现很奇怪的错误,而不是这么明显的乱码,你怎么抓bug都抓 ...

  7. PI-安装SoapUI on Windows

    SoapUI是测试webservice连通性的工具,请见博文:http://www.dekevin.com/?p=1807 当你下载好了SOAPUI的安装程序之后,就可以进行程序的安装了,怎么来进行S ...

  8. DB9 公头母头引脚定义及连接

    1.实物及引脚简单介绍 在做开发的时候常常会用到串行接口,一般9针的串行接口居多.例如以下图所看到的: 公头母头用于连接线的採用上图封装.但用于开发板的时候採用90度弯角插针的封装.例如以下图: 各引 ...

  9. asp.net mvc控制器动作体返回ImageResult,可作验证码

    public ActionResult Img() { // 获取博客园空间顶部的banner图片 WebRequest req = WebRequest.Create("http://sp ...

  10. CSAPP缓冲区溢出攻击实验(上)

    CSAPP缓冲区溢出攻击实验(上) 下载实验工具.最新的讲义在这. 网上能找到的实验材料有些旧了,有的地方跟最新的handout对不上.只是没有关系,大体上仅仅是程序名(sendstring)或者參数 ...