使用DBV(DB File Verify)工具檢查數據壞塊


一、介紹

DBV(DBVERIFY)是oracle提供的一個命令行工具,它可以對數據文件物理和邏輯兩種一致性檢查。但是這個工具不會檢查索引記錄和數據記錄的匹配關系,這種檢查必須使用analyze validate structure命令。

這個工具有如下特點:

  • 以只讀的方式打開數據文件,在檢查過程中不會修改數據文件的內容。
  • 可以在線檢查數據文件,而不需要關閉數據庫。
  • 不能檢查控制文件和日志文件,只能檢查數據文件。
  • 這個工具可以檢查ASM文件,但數據庫必須Open狀態,並且需要通過USERID指定用戶,比如:dbv file=+DG1/ORCL/datafile/system01.dbf userid=system/sys
  • 在許多UNIX平台下,DBV要求數據文件有擴展名,如果沒有可以通過建立鏈接的方法,然后對鏈接的方法,然后對鏈接文件進行操作,比如:ls -n /dev/rdsk/mydevice /tmp/mydevice.dbf
  • 某些平台,DBV工具不能檢查超過2GB的文件,如果碰到DBV-100錯誤,請先檢查文件大小,MOS Bug 710888對這個問題有描述。
  • DBV只會檢查數據塊的正確性,但不會關系數據塊是否屬於哪個對象。
  • 對於祼設備建議指定END參數,避免超出數據文件范圍。比如:dbv FILE=/dev/rdsk/r1.dbf END=<last_block_number>。可以在v$datafile視圖中用bytes字段除以塊大小來獲得END值。

 

參數

含義

缺省值

FILE

要檢查的數據文件名

沒有缺省值

START

檢查起始數據塊號

數據文件的第一個數據塊

END

檢查的最后一個數據塊號

數據文件的最后一個數據塊

BLOCKSIZE

數據塊大小,這個值要和數據庫的DB_BLOCK_SIZE參數值一致

缺省值8192

LOGFILE

檢查結果日志文件

沒有缺省值

FEEDBAK

顯示進度

0

PARFILE

參數文件名

沒有缺省值

USERID

用戶名、密碼

沒有缺省值。驗證ASM時需要指定

SEGMENT_ID

段ID,參數格式<tsn.segfile.segblock>

沒有缺省值

 

二、簡單使用

ORA-01578: ORACLE data block corrupted (file # 64, block # 1520947)

ORA-01110: data file 64: '/data1/test/datafile/users02.dbf '

 

[oracle@test datafile]$ dbv file=users02.dbf

DBVERIFY: Release 11.2.0.4.0 - Production on 星期日 9月 27 09:50:19 2020

 

Copyright (c) 1982, 2011, Oracle and/or its affiliates.  All rights reserved.

 

DBVERIFY - Verification starting : FILE = /data1/test/datafile/users02.dbf

 

 

DBVERIFY - Verification complete

 

Total Pages Examined         : 4096000                   --檢查總頁數

Total Pages Processed (Data) : 2728901                                     --處理的總頁數(數據)

Total Pages Failing   (Data) : 0                                           --總頁數失敗(數據)

Total Pages Processed (Index): 361908                              --處理的總頁數(索引)

Total Pages Failing   (Index): 0                                           --總頁面失敗(索引)

Total Pages Processed (Other): 31105                                --處理的總頁數(其他)

Total Pages Processed (Seg)  : 0                                         --處理的總頁數(seg)

Total Pages Failing   (Seg)  : 0                                          --總頁數失敗(seg)

Total Pages Empty            : 974086                            --總頁數空

Total Pages Marked Corrupt   : 0                                       --總頁數標記為損壞

Total Pages Influx           : 0                                         --總頁面數量

Total Pages Encrypted        : 0                                      --加密總頁數

Highest block SCN            : 299697043 (27.299697043)     --最高塊SCN

 

 

限制

1.DBV受版本限制,高版本可以自動識別低版本數據庫,比如11g的dbv訪問9i的數據庫,但是低版本的dbv訪問高版本會報錯。
2.不支持聯機日志文件,歸檔日志,RMAN備份集驗證

3. 在許多Unix平台,DBV要求數據文件要有擴展名,如果沒有可建立軟連接:

ln -s /dev/rdsk/mydevice /tmp/mydevice.dbf


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM