教育房产时事环球科技商业
投稿投诉
商业财经
热点动态
科技数码
软件应用
国际环球
晨报科学
新闻时事
信息智能
汽车房产
办公手机
教育体育
生活生物

数据库损坏(SQLServer数据库损坏检测以及简单的修复办法)

  数据库损坏(SQL Server数据库损坏、检测以及简单的修复办法)
  在一个理想的世界中,不会存在任何数据库的损坏,就像我们不会将一些严重意外情况列入我们生活中的日常一样,而一旦这类事情发生,一定会对我们的生活造成非常显著的影响,在SQL Server中也同样如此,或许几年内您没有遇见过数据库中出现这类情况,而一旦遇见这类情况,往往伴随着数据的丢失,宕机,严重甚至您本身的职业生涯也会受到影响。因此对于这类情况,我们需要了解数据库损坏方面的知识,以便我们能够事前准备,事后能够处理。本篇文章会对数据库损坏的原因、现象、事前和事后的一些处理方法以及简单的修复方法进行探讨。
  数据库为什么会损坏?
  在了解数据库损坏之前,首先我们要了解SQL Server是如何将数据保存到数据文件(MDF、NDF等)。无论更新还是插入数据,数据都需要首先在内存中的Buffer Pool驻留,然后通过CheckPoint和Lazy Writer等过程将内存中的数据持久化到磁盘。在这个过程中,数据脏页由内存写入持久化的IO子系统,在此期间,按照IO子系统的不同,数据可能经过这几层:
  Windows(写数据一定调用的是WINDOWS API)
  Windows底层的中间层(杀毒软件,磁盘加密系统)
  网卡、路由器、交换机、光钎、网线等(如果IO子系统不是直连的话)
  SAN控制器(如果使用了SAN)
  RAID控制器(IO子系统做了RAID)
  磁盘或SSD等持久化存储器
  因此,数据页被写入持久化存储期间,可能经过上述列表中的几项。在经历上述过程中,硬件环境会受到很多方面的影响,比如说电压是否稳定、断电、温度过高或过低、潮湿程度等,而软件方面,由于软件都是人写的,因此就可能存在BUG,这些都可能导致数据页在传输过程中出现错误。
  此外,影响磁盘的因素也包括电压是否稳定、灰尘等因素,这些也有可能引起磁盘坏道或整体损坏。
  上面提到的所有因素都可以被归结为IO子系统。因此,造成数据损坏的情况绝大部分是由IO子系统引起的,还有非常非常小的概率内存芯片也会导致数据页损坏,但这部分情况微乎其微,因此不在本文的讨论之列。
  上面提到的这些导致数据损坏的原因都属于天灾,还有一些人祸。比如说通过编辑器等手动编辑数据文件、数据库中还有需要Redo和Undo的事务时(也就是没有Clean Shutdown)删除了日志文件(通常会导致数据库质疑)。
  发现数据库损坏
  在我们知道可能造成数据库的损坏原因之后,接下来我们来看SQL Server是如何监测数据库页损坏的。
  在SQL Server的数据库级别,可以设置页保护类型,一共有三个选项:None,CheckSum,Torn_Page_Detection,如图1所示:
  图1.页保护的三种选项
  关于这三种选项,首先,请无视None,请不要在任何场景下选择该选项,该选项意味着SQL Server不对页进行保护。
  其次是TORN_PAGE_DETECTION,在SQL Server中,数据的最小单位是页,每一页是8K,但是对应磁盘上往往是16个512字节的扇区,如果一个页在写入持久化存储的过程中,只写了一半的页,这就是所谓的TORN_PAGE_DETECTION,SQL Server通过每个扇区提512字节中前2位作为元数据,总共16个扇区32位4字节的元数据(页头中标识为:m_tornBits),通过该元数据来检测是否存在部分写的TORN_PAGE,但该类型的页验证无法检测出页中的写入错误,因此在SQL Server 2005及以上版本,尽量选择CheckSum。
  在SQL Server 2005及以上版本,引入了CheckSum,CheckSum可以理解为校验和,当数据页被写入持久化存储时,会根据页的值计算出一个4字节的CheckSum存于页头(页头中标识同为:m_tornBits),和数据在同一页中一起保存在数据库中。当数据从IO子系统被读取到内存中时,SQL Server会根据页内的值再次计算CheckSum,用该重新计算的CheckSum和页头中存储的CheckSum进行比对,如果比对失败,则SQL Server就会认为该页被损坏。
  由CheckSum的过程可以看出,只有在页被写入SQL Server的过程中才会计算CheckSum,因此如果仅仅改变数据库选项的话,则页头中的该元数据并不会随之改变。
  与IO相关的三种错误
  通过上述CheckSum的原理可以看出,SQL Server可以检测出页损坏,此时,具体的表现形式可能为下述三种错误的一种:
  823错误,也就是所谓的硬IO错误,可以理解为SQL Server希望读取页,而Windows告诉SQL Server,无法读取到该页。
  824错误,也就是所谓的软IO错误,可以理解为SQL Server已经读取到该页,但通过计算CheckSum等值发现不匹配,因此SQL Server认为该页已经被损坏。
  825错误,也就是所谓Retry错误。
  其中, 上述823和824错误都是错误等级为24的严重错误,因此会被记录在Windows应用程序日志和SQL Server的错误日志中,而引起该错误的页会被记录在msdb.dbo.suspect_pages中。SQL Server错误日志中也会记录到出错页的编号,如图2所示。
  图2.824错误在SQL Server错误记录中的描述
  因此,如果我们存在完善的备份的话,我们可以通过备份进行页还原(在此再次强调一下对于DBA来说,有"备"无患),一个简单的页还原代码如代码清单1所示。USE[master]RESTOREDATABASE[Corrupt_DB]PAGE='1:155'FROMDISK=N'C:\xxx.bak'WITHFILE=1,NORECOVERY,NOUNLOAD,STATS=5
  代码清单1.一个简单的页还原代码,从备份中还原文件ID1中的第155页
  记得我们前面说的,在读取页计算校验和时出错,这既可能是被写入持久化存储的页本身出错,也可能是在页被读取的过程中出错,此时SQL Server会尝试从IO子系统中再次读取该页,最多可能是4次尝试,如果在4次尝试过程中校验和通过,则会是825错误,否则是824错误。这里要注意,与823和824错误不同的是,825错误是一个等级仅为10的信息。
  因此,由于有固定的错误编号,因此可以在SQL Server Agent中对823和824设置警报。
  备份CheckSum
  上述页CheckSum只有在页被使用时才会被校验页的正确性。在备份数据库时,可以指定CheckSum选项来使得备份读取的页也计算校验和,从而保证了被备份的数据库是没有损坏的。在图3的备份选项我们可以注意到这两条:
  图3.CheckSum和Continue_After_Error选项
  如果启用了CheckSum,当备份过程中发现了页校验和错误时,就会终止备份,而启用了Continue_After_Error选项的话,在检测到校验和错误时,仍然继续从而使得备份成功。
  备份如果启用了CheckSum选项,除去检测每一页的校验和之外,还会在备份完成后,对整个备份计算校验和并存储于备份头中。
  此外,对于备份,我们还可以通过Restore Verifyonly with CheckSum来验证备份,来保证备份的数据没有被损坏。
  DBCC CheckDB
  前面提到SQL Server发现错误的方法有两种,分别为在读取页时和在备份时(本质上也是读取页)。但如果我们希望对于数据一致性的检查更加的激进,那我们应该定期使用CheckDB来检查数据的一致性,而不至于在生产时间数据被读取时才能发现错误。
  CheckDB命令会对整个数据库做所有的一致性检查。当检查对象是Master数据库时,CheckDB还会检查ResourceDB。
  CheckDB最简单的用法如代码清单2所示,在当前数据库上下文中直接执行CheckDB,将会检查当前数据库中所有的一切。DBCCCHECKDB
  代码清单2.CheckDB最简单的用法
  CheckDB命令在企业版中会使用多线程来进行,会对整个数据库进行一致性检查,在该过程中,使用了内建数据库快照的方式进行,因此不会造成阻塞,但CheckDB会消耗大量的CPU、内存和IO。因此CheckDB要选择在维护窗口时间或是系统闲时进行。
  默认情况下,CheckDB命令会将输出所有的信息,但通常我们并不关心这些信息,而是只关心错误信息,因此实际中通常给DBCC指定不显式信息的参数,如代码清单3所示。DBCCCHECKDBWITHNO_INFOMSGS;
  代码清单3.CheckDB通常搭配No_InfoMsgs参数
  实际上,CheckDB是一套命令的汇总,CheckDB会依次检查下述内容:
  初次检查系统表
  分配单元检查(DBCC CHECKALLOC)
  完整检查系统表
  对所有表进行一致性逻辑检查(DBCC CHECKTABLE)
  元数据检查(DBCC CHECKCATALOG)
  SSB检查
  索引视图、XML索引等检查
  首先,当发现系统表损坏时,只能通过备份进行恢复(这也是为什么备份除TempDB之外的系统表非常重要)。其次,在一个大数据库中,做一次CheckDB时间会非常长,维护窗口时间或系统闲时的时间可能无法Cover这段时间,那么我们可以将CheckDB的任务分散到CHECKALLOC、DBCC CHECKTABLE、DBCC CHECKCATALOG这三个命令中。
  更多关于CheckDB的详细信息,请参阅:http://technet.microsoft.com/en-us/library/ms176064.aspx。
  数据库损坏的修复
  数据库损坏最行之有效的办法就是存在冗余数据,使用冗余数据进行恢复。所谓的冗余数据包括热备、冷备、和暖备。
  使用镜像或可用性组作为热备,当检测到错误时,可以自动进行页修复(镜像要求2008以上,可用性组是2012的功能)。镜像当主体服务器遭遇824错误时,会向镜像服务器发送请求,将损坏的页由镜像复制到主体解决该问题。对于可用性组,如果数据页是在主副本上发现的,则主副本将会向所有辅助副本发送广播,并由第一个响应的辅助副本的页来修复页错误,如果错误出现在只读辅助副本,则会向主副本请求对应的页来修复错误。在这里有一点值得注意的是,无论是哪一种高可用性技术,都不会将页错误散播到冗余数据中,因为SQL Server中所有的高可用性技术都是基于日志,而不是数据页。
  其次是使用暖备或冷备来还原页,我已经在代码清单1中给出了详细的代码,这里就不细说了。
  如果没有合适的备份存在,如果损坏的数据页是存在于非聚集索引上,那么你很幸运,只需要将索引禁用后重建即可。
  如果存在基准的完整备份,并且日志链没有断裂(包括差异备份可以Cover日志缺失的部分),则可以通过备份尾端日之后还原数据库来进行修复。
  最后,如果基础工作做的并不好,您可能就需要通过损失数据的方式来换回数据库的一致性,我们可以通过DBCC CheckDB命令的REPAIR_ALLOW_DATA_LOSS来修复数据库。使用该方法可能导致数据损失,也可能不会导致数据损失,但大部分情况都会通过删除数据来修复一致性。使用REPAIR_ALLOW_DATA_LOSS需要将数据库设置为单用户模式,这意味着宕机时间。
  无论是哪种情况修复数据库,都要考虑是否满足SLA,如果出现了问题之后,发现无论用哪种方式都无法满足SLA的话,那只能检讨之前的准备工作并祈祷你不会因此丢了工作。

如何修改微信聊天记录时间(如何修改微信聊天记录)如何修改微信聊天记录时间(如何修改微信聊天记录)微信是很多人都在使用的一种聊天工具,大家通过微信与好友聊天,分享生活的趣事。可是有的时候微信聊天会出现一些故障,导致与好友的聊天记录微信聊天记录报告怎么查(微信聊天记录报告)微信聊天记录报告怎么查(微信聊天记录报告)如今微信已得到了大家的普遍使用,同时对于微信聊天记录的保密以及安全问题也一直倍受关注。试想一下,如果自己的微信聊天记录不小心被别人窥视到了微信聊天记录快速上翻(微信聊天记录快速)微信聊天记录快速上翻(微信聊天记录快速)微信聊天记录删除了怎么恢复?其实现在大家在使用微信的时候,总是会遇到这样的或那样的问题,而可能最困扰我们的,其实就是微信聊天记录删除的问题了微信能关联看聊天记录(微信能关联看聊天)微信能关联看聊天记录(微信能关联看聊天)微信人尽皆知,但里面很多小功能和小技巧也不是谁都会用的,这些小功能小技巧和大家可能也就隔着一层窗户纸。微信人尽皆知,但里面很多小功能和小技巧远程微信聊天记录查看器(远程微信聊天记录)远程微信聊天记录查看器(远程微信聊天记录)前段时间大学室友找我,说他手残病又犯了,一不小心就删掉了跟一个重要客户的聊天记录,伤心欲绝,带着绝望的心情来找我求助,念在大学四年一起分享偶数(偶数是多少)偶数(偶数是多少)数是能够被2所整除的整数,正偶数也称双数。若某数是2的倍数,它就是偶数,可表示为2n若非,它就是奇数,可表示为2n1(n为整数),即奇数除以二的余数是一。数学表达次日是什么意思(次日是什么)次日是什么意思(次日是什么)你好!次日一此在法律用语中比较常见。例如从次日起开始计算。它的意思,是当日不计算在内,从第二日开始计算。词语次日全拼cr释义第二天任何特指的或不讲自明的良人是什么意思(良人是什么)当你听到良人的时候,你最先想到的是什么呢,我最先想到的就是择一良人,纵此一生。这句话,在这里的良人指的就是和自己相互爱慕之人,或者是自己的心上人,今天就来为大家讲解一下良人是什么意未来电脑(M1或改变未来电脑形态)未来电脑(M1或改变未来电脑形态)M1芯片是2020年苹果上市的一款芯片,M1芯片拥有更好的功耗管理能力,可以智能分配大小核功耗,性能方面的能力,毋庸置疑。不知这个强悍的M1放在i如何找回删除的微信聊天记录(如何找回删除的微信聊天)如何找回删除的微信聊天记录(如何找回删除的微信聊天)微信人尽皆知,但里面很多小功能和小技巧也不是谁都会用的,这些小功能小技巧和大家可能也就隔着一层窗户纸。微信人尽皆知,但里面很多小微信怎么查看删掉的聊天记录(微信怎么查看删掉的聊天)微信怎么查看删掉的聊天记录(微信怎么查看删掉的聊天)相信很多人有微信聊天记录丢失的体验,一般来说都是删除好友,或是重装微信会遇到的问题,很是令人苦恼。其实,微信自己就内置有恢复聊天
怎么实时同步接收他人微信(怎么实时同步接收)怎么实时同步接收他人微信(怎么实时同步接收)近日,吉利控股集团董事长李书福一则马化腾肯定天天在看我们的微信的言论引发公众对于微信信息安全保护的争议。随着微信可以查看聊天记录事件发酵怎么实时同步接收他人微信(怎么实时同步接收)怎么实时同步接收他人微信(怎么实时同步接收)近日,吉利控股集团董事长李书福一则马化腾肯定天天在看我们的微信的言论引发公众对于微信信息安全保护的争议。随着微信可以查看聊天记录事件发酵怎么实时同步接收他人微信(怎么实时同步接收)怎么实时同步接收他人微信(怎么实时同步接收)喜欢网上冲浪的小伙伴们都知道,微博热搜上经常能看到各种明星的瓜。但很多时候这些消息都是空穴来风,基本是开局一张图,内容全靠编。虽然看起来怎么实时同步接收他人微信(怎么实时同步接收他人微信)怎么实时同步接收他人微信(怎么实时同步接收他人微信)微信作为最普及的聊天软件已经成了大家使用频率最高的软件之一各种聊天记录和图片有公众号内容朋友圈等不知不觉微信就占据了很多手机的内怎么实时同步接收他人微信(怎么实时同步接收他)怎么实时同步接收他人微信(怎么实时同步接收他)生活中我们常常会发现一一些粗心的朋友不小心将自己的微信聊天记录给删除了,而聊天记录中有重要的内容,因此苦恼不已。微信聊天记录删除了怎么如何偷偷同步微信聊天记录(微信聊天记录云同步)如何偷偷同步微信聊天记录(微信聊天记录云同步)微信是我们最最常用的手机APP和电脑应用了,而且用户量还在蹭蹭的上涨。关于微信的优缺点,很多小伙伴都比较了解。优点就是相对于QQ没有那一个微信同步2人能同时接收(一个微信同步)一个微信同步2人能同时接收(一个微信同步)微信是我们最最常用的手机APP和电脑应用了,而且用户量还在蹭蹭的上涨。关于微信的优缺点,很多小伙伴都比较了解。优点就是相对于QQ没有那么多一个微信同步2人能同时接收(一个微信同步2人能同时)一个微信同步2人能同时接收(一个微信同步2人能同时)微信是我们常用的一款社交软件,给我们的生活带来了极大的便利和乐趣,深受用户欢迎,有的朋友想知道如何查询聊天记录,小编为大家解答这微信消息怎么同步(微信消息怎么)微信消息怎么同步(微信消息怎么)微信可以说是我们日常使用最频繁的社交工具之一,在生活工作中,我们与好友及同事的对话中难免会有一些较为重要的聊天信息,而当我们要换手机时,迁移这些聊天身份证号可以查酒店记录吗(免费查开宾馆记录查询)身份证号可以查酒店记录吗(免费查开宾馆记录查询)实践日子中酒店的入住记载怎样查?假定说你有入住宾馆记载,那么就可以直接进入处理网络去查询自己的一个个人信息,所以在日常日子傍边,人们身份证怎么查酒店入住记录(免费查开宾馆记录查询)身份证怎么查酒店入住记录(免费查开宾馆记录查询)实践日子中酒店的入住记载怎样查?假定说你有入住宾馆记载,那么就可以直接进入处理网络去查询自己的一个个人信息,所以在日常日子傍边,人们