DBV命令行工具檢測(cè)壞塊
一,介紹
DBV(DBVERIFY)是Oracle提供的一個(gè)命令行工具,它可以對(duì)數(shù)據(jù)文件物理和邏輯兩種一致性檢查。但是這個(gè)工具不會(huì)檢查索引記錄和數(shù)據(jù)記錄的匹配關(guān)系,這種檢查必須使用analyze validate structure命令。
這個(gè)工具有如下特點(diǎn):
以只讀的方式打開(kāi)數(shù)據(jù)文件,在檢查過(guò)程中不會(huì)修改數(shù)據(jù)文件的內(nèi)容。
可以在線檢查數(shù)據(jù)文件,而不需要關(guān)閉數(shù)據(jù)庫(kù)。
不能檢查控制文件和日志文件,只能檢查數(shù)據(jù)文件。
這個(gè)工具可以檢查ASM文件,但數(shù)據(jù)庫(kù)必須Open狀態(tài),并且需要通過(guò)USERID指定用戶,比如:dbv file=+
DG1/ORCL/datafile/system01.dbf userid=system/sys
在許多UNIX平臺(tái)下,DBV要求數(shù)據(jù)文件有擴(kuò)展名,如果沒(méi)有可以通過(guò)建立鏈接的方法,然后對(duì)鏈接的方法,然后對(duì)鏈接文件進(jìn)行操作,比如:ls -n /dev/rdsk/mydevice /tmp/mydevice.dbf
某些平臺(tái),DBV工具不能檢查超過(guò)2GB的文件,如果碰到DBV-100錯(cuò)誤,請(qǐng)先檢查文件大小,MOS Bug 710888對(duì)這個(gè)問(wèn)題有描述。
DBV只會(huì)檢查數(shù)據(jù)塊的正確性,但不會(huì)關(guān)系數(shù)據(jù)塊是否屬于哪個(gè)對(duì)象。
對(duì)于祼設(shè)備建議指定END參數(shù),避免超出數(shù)據(jù)文件范圍。比如:dbv FILE=/dev/rdsk/r1.dbf END=<last_block_number>。可以在v$datafile視圖中用bytes字段除以塊大小來(lái)獲得END值。
參數(shù) 含義 缺省值
FILE 要檢查的數(shù)據(jù)文件名 沒(méi)有缺省值
START 檢查起始數(shù)據(jù)塊號(hào) 數(shù)據(jù)文件的第一個(gè)數(shù)據(jù)塊
END 檢查的最后一個(gè)數(shù)據(jù)塊號(hào) 數(shù)據(jù)文件的最后一個(gè)數(shù)據(jù)塊
BLOCKSIZE 數(shù)據(jù)塊大小,這個(gè)值要和數(shù)據(jù)庫(kù)的DB_BLOCK_SIZE參數(shù)值一致 缺省值8192
LOGFILE 檢查結(jié)果日志文件 沒(méi)有缺省值
FEEDBAK 顯示進(jìn)度 0
PARFILE 參數(shù)文件名 沒(méi)有缺省值
USERID 用戶名、密碼 沒(méi)有缺省值
SEGMENT_ID 段ID,參數(shù)格式<tsn.segfile.segblock> 沒(méi)有缺省值
二,簡(jiǎn)單使用
[oracle@oracle01 oracle01]$ dbv file=test01.dbf
--最好是絕對(duì)路徑,這里是進(jìn)入到對(duì)應(yīng)目錄下,所以用相對(duì)路徑
DBVERIFY: Release 11.2.0.4.0 - Production on Mon May 13 15:21:42 2019
Copyright (c) 1982, 2011, Oracle and/or its affiliates. All rights reserved.
DBVERIFY - Verification starting : FILE =
/u01/app/oracle/oradata/oracle01/test01.dbf
DBVERIFY - Verification complete
Total Pages Examined : 1280 --( 檢查總頁(yè)數(shù))
Total Pages Processed (Data) : 5 --(處理的總頁(yè)數(shù)(數(shù)據(jù)))
Total Pages Failing (Data) : 0 --(總頁(yè)數(shù)失?。〝?shù)據(jù)))
Total Pages Processed (Index): 0 --(處理的總頁(yè)數(shù)(索引))
Total Pages Failing (Index): 0 --(總頁(yè)面失敗(索引))
Total Pages Processed (Other): 136 --(處理的總頁(yè)數(shù)(其他))
Total Pages Processed (Seg) : 0 --(處理的總頁(yè)數(shù)(Seg))
Total Pages Failing (Seg) : 0 --(總頁(yè)數(shù)失?。⊿eg)
Total Pages Empty : 1139 --(總頁(yè)數(shù)空)
Total Pages Marked Corrupt : 0 --(總頁(yè)數(shù)標(biāo)記為損壞)
Total Pages Influx : 0 --(總頁(yè)面數(shù)量)
Total Pages Encrypted : 0 --(加密總頁(yè)數(shù))
Highest block SCN : 11638862 (0.11638862) --(最高塊SCN)
這個(gè)工具報(bào)告使用的是page作為單位,含義和data block相同。從上面的檢查結(jié)果Total Pages Marked Corrupt : 0可以看出文件沒(méi)有壞塊。
除了檢查數(shù)據(jù)文件,這個(gè)工具還允許檢查單獨(dú)的Segment,這時(shí)參數(shù)值的格式為<tsn.segfile.segblock>
查看對(duì)象的tsn,segfile,segblock屬性:
SQL> select t.ts#,s.header_file,s.header_block
from v$tablespace t,dba_segments s
where s.segment_name='T'
and t.name=s.tablespace_name; 2 3 4
0 1 96544
從上面的查詢結(jié)果可行參數(shù)值為0.1.96544。檢查Segment:
[oracle@oracle01 oracle01]$ dbv userid=system/123456 segment_id=0.1.96544
DBVERIFY: Release 11.2.0.4.0 - Production on Mon May 13 15:27:53 2019
Copyright (c) 1982, 2011, Oracle and/or its affiliates. All rights reserved.
DBVERIFY - Verification starting : SEGMENT_ID = 0.1.96544
DBVERIFY - Verification complete
Total Pages Examined : 2
Total Pages Processed (Data) : 1
Total Pages Failing (Data) : 0
Total Pages Processed (Index): 0
Total Pages Failing (Index): 0
Total Pages Processed (Other): 0
Total Pages Processed (Seg) : 1
Total Pages Failing (Seg) : 0
Total Pages Empty : 0
Total Pages Marked Corrupt : 0
Total Pages Influx : 0
Total Pages Encrypted : 0
Highest block SCN : 11645088 (0.11645088)
