SQL Server誤區(qū)30日談 第27天 使用BACKUP WITH CHECKSUM可以替代DBCC CheckDB
更新時(shí)間:2013年01月09日 22:08:54 作者:
乍一看,由于BACKUP WITH CHECKSUM會(huì)檢測(cè)所有分配出去的頁(yè)的校驗(yàn)和的值,這個(gè)誤區(qū)貌似是這么回事,但實(shí)際上并不是這么回事
誤區(qū) #27:使用BACKUP ... WITH CHECKSUM可以替代DBCC CheckDB
錯(cuò)誤
乍一看,由于BACKUP WITH CHECKSUM會(huì)檢測(cè)所有分配出去的頁(yè)的校驗(yàn)和的值,這個(gè)誤區(qū)貌似是這么回事,但實(shí)際上并不是這么回事,原因如下:
由SQL Server 2000或是更早版本升上來的數(shù)據(jù)庫(kù)page checksums必須開啟,在開啟后,并不是數(shù)據(jù)庫(kù)中所有的頁(yè)都會(huì)被叫上頁(yè)校驗(yàn)和,當(dāng)頁(yè)損壞發(fā)生時(shí),IO系統(tǒng)可不會(huì)區(qū)分損壞的頁(yè)是有頁(yè)校驗(yàn)和還是沒有校驗(yàn)和的。所以使用BACKUP ... WITH CHECKSUM就有可能導(dǎo)致一些損壞頁(yè)不被發(fā)現(xiàn),造成的后果……
除此之外,還有一個(gè)問題是完整備份的時(shí)間間隔相對(duì)比較長(zhǎng),假如說一個(gè)月,而相對(duì)于DBCC CheckDB的最佳實(shí)踐是一個(gè)禮拜,這導(dǎo)致WITH CHECKSUM不能替代CHECKDB。即使你每周都進(jìn)行差異備份,但差異備份只會(huì)檢測(cè)差異部分的頁(yè)校驗(yàn)和。
最后一點(diǎn),也是危害最大的一點(diǎn),就是使用BACKUP WITH CHECKSUM選項(xiàng)不能發(fā)現(xiàn)內(nèi)存中的頁(yè)損壞。這是因?yàn)橛捎趦?nèi)存芯片或是WINDOWS進(jìn)程導(dǎo)致內(nèi)存中的頁(yè)損壞,并且在這之后寫回磁盤。這導(dǎo)致?lián)p壞頁(yè)卻有正常的校驗(yàn)和,只有使用DBCC CheckDB才能發(fā)現(xiàn)這類錯(cuò)誤。
因此,說到底,你必須經(jīng)常使用DBCC CHECKDB,如果對(duì)此你仍然心存疑問,請(qǐng)看我之前的一篇文章:CHECKDB From Every Angle: Consistency Checking Options for a VLDB。
擴(kuò)展閱讀:Search Engine Q&A #26: Myths around causing corruption
錯(cuò)誤
乍一看,由于BACKUP WITH CHECKSUM會(huì)檢測(cè)所有分配出去的頁(yè)的校驗(yàn)和的值,這個(gè)誤區(qū)貌似是這么回事,但實(shí)際上并不是這么回事,原因如下:
由SQL Server 2000或是更早版本升上來的數(shù)據(jù)庫(kù)page checksums必須開啟,在開啟后,并不是數(shù)據(jù)庫(kù)中所有的頁(yè)都會(huì)被叫上頁(yè)校驗(yàn)和,當(dāng)頁(yè)損壞發(fā)生時(shí),IO系統(tǒng)可不會(huì)區(qū)分損壞的頁(yè)是有頁(yè)校驗(yàn)和還是沒有校驗(yàn)和的。所以使用BACKUP ... WITH CHECKSUM就有可能導(dǎo)致一些損壞頁(yè)不被發(fā)現(xiàn),造成的后果……
除此之外,還有一個(gè)問題是完整備份的時(shí)間間隔相對(duì)比較長(zhǎng),假如說一個(gè)月,而相對(duì)于DBCC CheckDB的最佳實(shí)踐是一個(gè)禮拜,這導(dǎo)致WITH CHECKSUM不能替代CHECKDB。即使你每周都進(jìn)行差異備份,但差異備份只會(huì)檢測(cè)差異部分的頁(yè)校驗(yàn)和。
最后一點(diǎn),也是危害最大的一點(diǎn),就是使用BACKUP WITH CHECKSUM選項(xiàng)不能發(fā)現(xiàn)內(nèi)存中的頁(yè)損壞。這是因?yàn)橛捎趦?nèi)存芯片或是WINDOWS進(jìn)程導(dǎo)致內(nèi)存中的頁(yè)損壞,并且在這之后寫回磁盤。這導(dǎo)致?lián)p壞頁(yè)卻有正常的校驗(yàn)和,只有使用DBCC CheckDB才能發(fā)現(xiàn)這類錯(cuò)誤。
因此,說到底,你必須經(jīng)常使用DBCC CHECKDB,如果對(duì)此你仍然心存疑問,請(qǐng)看我之前的一篇文章:CHECKDB From Every Angle: Consistency Checking Options for a VLDB。
擴(kuò)展閱讀:Search Engine Q&A #26: Myths around causing corruption
您可能感興趣的文章:
- SQL Server誤區(qū)30日談 第29天 有關(guān)堆碎片的誤區(qū)
- SQL Server誤區(qū)30日談 第28天 有關(guān)大容量事務(wù)日志恢復(fù)模式的誤區(qū)
- SQL Server誤區(qū)30日談 第26天 SQL Server中存在真正的“事務(wù)嵌套”
- SQL Server誤區(qū)30日談 第25天 有關(guān)填充因子的誤區(qū)
- SQL Server誤區(qū)30日談 第24天 26個(gè)有關(guān)還原(Restore)的誤區(qū)
- SQL Server誤區(qū)30日談 第23天 有關(guān)鎖升級(jí)的誤區(qū)
- SQL Server誤區(qū)30日談 第22天 資源調(diào)控器可以調(diào)控IO
- SQL Server誤區(qū)30日談 第21天 數(shù)據(jù)損壞可以通過重啟SQL Server來修復(fù)
- SQL Server誤區(qū)30日談 第20天 破壞日志備份鏈之后,需要一個(gè)完整備份來重新開始日志鏈
- SQL Server誤區(qū)30日談 第19天 Truncate表的操作不會(huì)被記錄到日志
- SQL Server誤區(qū)30日談 第18天 有關(guān)FileStream的存儲(chǔ),垃圾回收以及其它
- SQL Server誤區(qū)30日談 第17天 有關(guān)頁(yè)校驗(yàn)和的誤區(qū)
- SQL Server誤區(qū)30日談 第16天 數(shù)據(jù)的損壞和修復(fù)
- SQL Server誤區(qū)30日談 第15天 CheckPoint只會(huì)將已提交的事務(wù)寫入磁盤
- SQL Server誤區(qū)30日談 第14天 清除日志后會(huì)將相關(guān)的LSN填零初始化
- SQL Server誤區(qū)30日談 第13天 在SQL Server 2000兼容模式下不能使用DMV
- SQL Server誤區(qū)30日談 第12天 TempDB的文件數(shù)和需要和CPU數(shù)目保持一致
- SQL Server誤區(qū)30日談 第11天 鏡像在檢測(cè)到故障后瞬間就能故障轉(zhuǎn)移
- SQL Server誤區(qū)30日談 第10天 數(shù)據(jù)庫(kù)鏡像在故障發(fā)生后 馬上就能發(fā)現(xiàn)
- SQL Server誤區(qū)30日談 第9天 數(shù)據(jù)庫(kù)文件收縮不會(huì)影響性能
- SQL Server誤區(qū)30日談 第8天 有關(guān)對(duì)索引進(jìn)行在線操作的誤區(qū)
- SQL Server誤區(qū)30日談 第7天 一個(gè)實(shí)例多個(gè)鏡像和日志傳送延遲
- SQL Server誤區(qū)30日談 第6天 有關(guān)NULL位圖的三個(gè)誤區(qū)
- SQL Server誤區(qū)30日談 第5天 AWE在64位SQL SERVER中必須開啟
- SQL Server誤區(qū)30日談 第4天 DDL觸發(fā)器就是INSTEAD OF觸發(fā)器
- SQL Server誤區(qū)30日談 第3天 即時(shí)文件初始化特性可以在SQL Server中開啟和關(guān)閉
- SQL Server誤區(qū)30日談 第2天 DBCC CHECKDB會(huì)導(dǎo)致阻塞
- SQL Server誤區(qū)30日談 第1天 正在運(yùn)行的事務(wù)在服務(wù)器故障轉(zhuǎn)移后繼續(xù)執(zhí)行
- SQL Server誤區(qū)30日談 第30天 有關(guān)備份的30個(gè)誤區(qū)
相關(guān)文章
SQL Server 數(shù)據(jù)庫(kù)管理常用的SQL和T-SQL語(yǔ)句
SQL Server 數(shù)據(jù)庫(kù)管理常用的SQL和T-SQL語(yǔ)句...2007-03-03SQL Server中聚合歷史備份信息對(duì)比數(shù)據(jù)庫(kù)增長(zhǎng)的方法
這篇文章主要介紹了SQL Server中聚合歷史備份信息對(duì)比數(shù)據(jù)庫(kù)增長(zhǎng)的方法,需要的朋友可以參考下2014-09-09通過SQLSERVER重啟SQLSERVER服務(wù)和計(jì)算機(jī)的方法
為了實(shí)現(xiàn)遠(yuǎn)程重新啟動(dòng),從而想到了用SQL語(yǔ)句命令實(shí)現(xiàn)這個(gè)功能,但是具體的命令格式給忘記了,找了點(diǎn)資料,把方法寫在下面2010-09-09