SQL Server误区30日谈 第20天 破坏日志备份链之后,需要一个完整备份来重新开始日志链
发布时间:2024-01-22 15:39:53
误区 #20:在破坏日志备份链之后,需要一个完整备份来重新开始日志链
错误
事务日志备份会备份自上次事务日志备份以来所有的事务日志(如果从来没有过日志备份的话,那就从上一次完整备份开始)。有好几种类型的操作会中断事务日志的连续性,也就是说除非重新开始新的日志链,SQL Server无法再进行日志备份。下面这几种操作都有可能引起日志链断裂:
由完整恢复模式或大容量事务日志恢复模式转为简单恢复模式
从数据库镜像进行恢复
备份日志时指定了NO_LOG 或 WITH TRUNCATE_ONLY(还好在SQL Server 2008中这个选项被取消了)
更多请看:post BACKUP LOG WITH NO_LOG - use, abuse, and undocumented trace flags to stop it
通过下面的例子对此进行阐述:
CREATE DATABASE LogChainTest;
GO
ALTER DATABASE LogChainTest SET RECOVERY FULL;
GO
BACKUP DATABASE LogChainTest TO DISK = 'C:\SQLskills\LogChainTest.bck' WITH INIT;
GO
BACKUP LOG LogChainTest TO DISK = 'C:\SQLskills\LogChainTest_log1.bck' WITH INIT;
GO
ALTER DATABASE LogChainTest SET RECOVERY SIMPLE;
GO
ALTER DATABASE LogChainTest SET RECOVERY FULL;
GO
结果是:
已为数据库 'LogChainTest',文件 'LogChainTest' (位于文件 1 上)处理了 168 页。
已为数据库 'LogChainTest',文件 'LogChainTest_log' (位于文件 1 上)处理了 2 页。
BACKUP DATABASE 成功处理了 170 页,花费 0.224 秒(5.916 MB/秒)。
已为数据库 'LogChainTest',文件 'LogChainTest_log' (位于文件 1 上)处理了 3 页。
BACKUP LOG 成功处理了 3 页,花费 0.121 秒(0.137 MB/秒)。
我首先创建了一个数据库,将其设置为完整恢复模式,这个是日志链的起点,然后转为简单恢复模式,再转为完整恢复模式。
下面我再尝试进行日志备份
BACKUP LOG LogChainTest TO DISK = 'C:\SQLskills\LogChainTest_log2.bck' WITH INIT;
GO
则会得到如下报错信息:
消息 4214,级别 16,状态 1,第 1 行
无法执行 BACKUP LOG,因为当前没有数据库备份。
消息 3013,级别 16,状态 1,第 1 行
BACKUP LOG 正在异常终止。
SQL Server已经记录了我破坏日志链的操作以及与进行日志 备份无法备份自上次日志备份以来所有的日志,所以SQL Server不允许我进行日志备份。
这个误区是说此时就需要完整备份才能恢复日志链,但实际上,我只需要做一个差异备份(这个差异备份的跨度超过日志链断裂的间隙),代码如下:
BACKUP DATABASE LogChainTest TO DISK = 'd:\Test_bak\LogChainTest_log1.bck' WITH INIT, DIFFERENTIAL;
GO
BACKUP LOG LogChainTest TO DISK = 'd:\Test_bak\LogChainTest_log1.bck' WITH INIT;
GO
得到的结果:
已为数据库 'LogChainTest',文件 'LogChainTest' (位于文件 1 上)处理了 64 页。
已为数据库 'LogChainTest',文件 'LogChainTest_log' (位于文件 1 上)处理了 1 页。
BACKUP DATABASE WITH DIFFERENTIAL 成功处理了 65 页,花费 0.119 秒(4.267 MB/秒)。
已为数据库 'LogChainTest',文件 'LogChainTest_log' (位于文件 1 上)处理了 1 页。
BACKUP LOG 成功处理了 1 页,花费 0.052 秒(0.150 MB/秒)。
不得不说这种方式更Cool一些,因为你不再需要一个完整备份才能继续进行日志备份。
如果你的备份策略中包含了文件或是文件组的备份,你甚至只需要单个文件的差异备份就能继续进行日志备份。但前提是这个备份的跨度超过了断裂LSN的长度,当然这是更深的话题了。
又揭穿了一个误区!


猜你喜欢
- 本文实例讲述了Python实现的ftp服务器功能。分享给大家供大家参考,具体如下:python 具备强大的网络编程功能,而且代码简介,用简单
- 先问一个问题, 在firefox 2里,正则表达式字符"\d"全等于"[0-9]"吗?有可能你会答&
- 01命名规则:项目名前面一数字编号,随着知识点递增,编号递增例如:01_python基础、02_分支、03_循环每个项目下的文件名建议使用小
- 本文实例讲述了Python比较文件夹比另一同名文件夹多出的文件并复制出来的方法。分享给大家供大家参考。具体如下:这个东东本来是做来给公司数据
- 这是群里一朋友问的问题,当时我说判断下 day 是否相邻即可,后来细想,发现完全不对。问题需求给定5个相同格式的日期,怎么判断是否是连续5天
- 由于 MySQL 5.7 版本的 root 密码是首次启动时随机生成的,并且还要求必须修改后才能使用,所以有了本文:使用 shell 脚本完
- 目录获取二维码部分获取关注状态值解析微信服务器报文大致思路:调用微信带参数二维码接口生成二维码,前端显示二维码同时于服务器进行长链接通信,监
- 今天来说说编程语言中的动态类型语言与鸭子类型。动态语言 * 对动态语言的定义:动态编程语言是一类在运行时可以改变其结构的语言:例如新的函数
- 今天来和大家聊聊抽样的几种常用方法,以及在Python中是如何实现的。抽样是统计学、机器学习中非常重要,也是经常用到的方法,因为大多时候使用
- 本文实例讲述了Python基于hashlib模块的文件MD5一致性加密验证。分享给大家供大家参考,具体如下:使用hashlib模块,可对文件
- 地理图表什么是地理图表?地理图表有什么作用?地理图表主要应用在那些领域?其实这些问题看看下面的实例图形就已不攻自破了,地理图表一看首先就是地
- 此方法支持IE 不支持火狐。可能是因为FCKEidtor的keyup方法在火狐下不被支持。 FCKEditor编辑器换为TextBox,应该
- 实战场景这次被我们盯上的平台是【SMZDM】。本次目标站点是:aHR0cHM6Ly93d3cuc216ZG0uY29tLw==。正式开始前,
- Mysql现在是大多数公司企业在用的数据库,之所以用Mysql,一点是因为Mysql是开源软件,一些有能力的公司会基于已有的Mysql架构,
- goland如果当前project用了版本控制器,其下面新建的所有的项目默认都是加入到版本控制里面,所以项目名称和文件都是红色的。解决办法:
- 一、介绍如果在Python中需要对用户输入的密码或者其他内容进行加密,首选的方法是生成hash值。在Python中可以利用二个模块来进行:&
- 有关函数HashBytes请参考:http://msdn.microsoft.com/en-us/library/ms174415.aspx
- 此文章主要向大家讲述的是SQL Server数据库的分布式数据库系统的实际目标,通俗的讲就是研制分布式数据库系统的目的、动机,其中主要包括的
- \\create by ahuinan 2009-6-22 \\up by ahuian 2009-6-23 \\up by ahuinan
- 老板由于事务繁忙无法经常亲临教研室,于是让我搞个监控系统,让他在办公室就能看到教研室来了多少人。o(>﹏<)o|||最初我的想法