天天看點

Oracle的DBV工具

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

顯示進度

PARFILE

參數檔案名

USERID

使用者名、密碼

SEGMENT_ID

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

使用示例:

<code>[oracle@rhel6 ~]$ dbv </code><code>file</code><code>=</code><code>/u01/app/oracle/oradata/test/users01</code><code>.dbf</code>

<code>DBVERIFY: Release 11.2.0.1.0 - Production on Mon May 22 16:42:26 2017</code>

<code>Copyright (c) 1982, 2009, Oracle and</code><code>/or</code> <code>its affiliates.  All rights reserved.</code>

<code>DBVERIFY - Verification starting : FILE = </code><code>/u01/app/oracle/oradata/test/users01</code><code>.dbf</code>

<code>DBVERIFY - Verification complete</code>

<code>Total Pages Examined         : 155520</code>

<code>Total Pages Processed (Data) : 144530</code>

<code>Total Pages Failing   (Data) : 0</code>

<code>Total Pages Processed (Index): 52</code>

<code>Total Pages Failing   (Index): 0</code>

<code>Total Pages Processed (Other): 1248</code>

<code>Total Pages Processed (Seg)  : 0</code>

<code>Total Pages Failing   (Seg)  : 0</code>

<code>Total Pages Empty            : 9690</code>

<code>Total Pages Marked Corrupt   : 0</code>

<code>Total Pages Influx           : 0</code>

<code>Total Pages Encrypted        : 0</code>

<code>Highest block SCN            : 3559792 (0.3559792)</code>

這個工具報告使用的是page作為機關,含義和data block相同。從上面的檢查結果Total Pages Marked Corrupt   : 0可以看出檔案沒有壞塊。

除了檢查資料檔案,這個工具還允許檢查單獨的Segment,這時參數值的格式為&lt;tsn.segfile.segblock&gt;

檢視對象的tsn,segfile,segblock屬性:

<code>zx@TEST&gt;</code><code>select</code> <code>t.ts#,s.header_file,s.header_block</code>

<code>  </code><code>2  </code><code>from</code> <code>v$tablespace t,dba_segments s</code>

<code>  </code><code>3  </code><code>where</code> <code>s.segment_name=</code><code>'T'</code>

<code>  </code><code>4  </code><code>and</code> <code>t.</code><code>name</code><code>=s.tablespace_name;</code>

<code>       </code><code>TS# HEADER_FILE HEADER_BLOCK</code>

<code>---------- ----------- ------------</code>

<code>         </code><code>4           4        45834</code>

從上面的查詢結果可行參數值為4.4.45834。檢查Segment:

<code>[oracle@rhel6 ~]$ dbv userid=system</code><code>/123456</code> <code>segment_id=4.4.45834</code>

<code>DBVERIFY: Release 11.2.0.1.0 - Production on Mon May 22 20:58:33 2017</code>

<code>DBVERIFY - Verification starting : SEGMENT_ID = 4.4.45834</code>

<code>Total Pages Examined         : 8</code>

<code>Total Pages Processed (Data) : 5</code>

<code>Total Pages Processed (Index): 0</code>

<code>Total Pages Processed (Other): 2</code>

<code>Total Pages Processed (Seg)  : 1</code>

<code>Total Pages Empty            : 0</code>

<code>Highest block SCN            : 3518579 (0.3518579)</code>

下面人為創造一個壞塊,用dbv來檢查。

建立一個測試表

<code>zx@TEST&gt;</code><code>create</code> <code>table</code> <code>bbed (id number,</code><code>name</code> <code>varchar2(20)) tablespace users;</code>

<code>Table</code> <code>created.</code>

<code>zx@TEST&gt;</code><code>insert</code> <code>into</code> <code>bbed </code><code>values</code><code>(1,</code><code>'zhaoxu'</code><code>);</code>

<code>1 row created.</code>

<code>zx@TEST&gt;</code><code>commit</code><code>;</code>

<code>Commit</code> <code>complete.</code>

目前資料檔案沒有壞塊

<code>DBVERIFY: Release 11.2.0.1.0 - Production on Mon May 22 21:03:40 2017</code>

<code>Total Pages Processed (Data) : 66397</code>

<code>Total Pages Processed (Other): 88898</code>

<code>Total Pages Empty            : 173</code>

<code>Highest block SCN            : 3764775 (0.3764775)</code>

擷取表在檔案中的存儲資訊

<code>zx@TEST&gt;</code><code>set</code> <code>serveroutput </code><code>on</code>

<code>zx@TEST&gt;</code><code>declare</code> <code>rfno number;</code>

<code>  </code><code>2  rtype number;</code>

<code>  </code><code>3  ono number;</code>

<code>  </code><code>4  blkno number;</code>

<code>  </code><code>5  rowno number;</code>

<code>  </code><code>6  rid varchar2(30);</code>

<code>  </code><code>7  </code><code>begin</code>

<code>  </code><code>8  </code><code>select</code> <code>rowid </code><code>into</code> <code>rid </code><code>from</code> <code>bbed;</code>

<code>  </code><code>9  dbms_rowid.rowid_info(ROWID_IN=&gt;rid,RELATIVE_FNO=&gt;rfno,BLOCK_NUMBER=&gt;blkno,ROW_NUMBER=&gt;rowno,ROWID_TYPE=&gt;rtype,OBJECT_NUMBER=&gt;ono);</code>

<code> </code><code>10  dbms_output.put_line(rfno||</code><code>','</code><code>||blkno||</code><code>','</code><code>||rowno);</code>

<code> </code><code>11  </code><code>end</code><code>;</code>

<code> </code><code>12  /</code>

<code>4,45844,0</code>

<code>PL/SQL </code><code>procedure</code> <code>successfully completed.</code>

使用bbed修改塊資訊

<code>[oracle@rhel6 bbed]$ bbed parfile=bbed.par</code>

<code>Password: </code>

<code>BBED: Release 2.0.0.0.0 - Limited Production on Mon May 22 21:17:18 2017</code>

<code>************* !!! For Oracle Internal Use only !!! ***************</code>

<code>BBED&gt; </code><code>set</code> <code>dba 4,45844</code>

<code>        </code><code>DBA             0x0100b314 (16823060 4,45844)</code>

<code>BBED&gt; </code><code>find</code> <code>/c</code> <code>zhaoxu</code>

<code> </code><code>File: </code><code>/u01/app/oracle/oradata/test/users01</code><code>.dbf (4)</code>

<code> </code><code>Block: 45844            Offsets: 8182 to 8191           Dba:0x0100b314</code>

<code>------------------------------------------------------------------------</code>

<code> </code><code>7a68616f 78750106 5873 </code>

<code> </code><code>&lt;32 bytes per line&gt;</code>

<code>BBED&gt; dump </code><code>/v</code> <code>dba 4,45844 offset 8182 count 32</code>

<code> </code><code>Block: 45844   Offsets: 8182 to 8191  Dba:0x0100b314</code>

<code>-------------------------------------------------------</code>

<code> </code><code>7a68616f 78750106 5873              l zhaoxu..Xs</code>

<code> </code><code>&lt;16 bytes per line&gt;</code>

<code>BBED&gt; modify 100 dba 4,45844</code>

<code>Warning: contents of previous BIFILE will be lost. Proceed? (Y</code><code>/N</code><code>) y</code>

<code> </code><code>6468616f 78750106 5873 </code>

<code> </code><code>6468616f 78750106 5873              l dhaoxu..Xs</code>

<code>BBED&gt; </code><code>exit</code>

再次使用dbv檢查檔案

<code>[oracle@rhel6 bbed]$ dbv </code><code>file</code><code>=</code><code>/u01/app/oracle/oradata/test/users01</code><code>.dbf</code>

<code>DBVERIFY: Release 11.2.0.1.0 - Production on Mon May 22 21:18:46 2017</code>

<code>Page 45844 is marked corrupt</code>

<code>Corrupt block relative dba: 0x0100b314 (</code><code>file</code> <code>4, block 45844)</code>

<code>Bad check value found during dbv: </code>

<code>Data </code><code>in</code> <code>bad block:</code>

<code> </code><code>type</code><code>: 6 </code><code>format</code><code>: 2 rdba: 0x0100b314</code>

<code> </code><code>last change scn: 0x0000.00397358 </code><code>seq</code><code>: 0x1 flg: 0x04</code>

<code> </code><code>spare1: 0x0 spare2: 0x0 spare3: 0x0</code>

<code> </code><code>consistency value </code><code>in</code> <code>tail</code><code>: 0x73580601</code>

<code> </code><code>check value </code><code>in</code> <code>block header: 0x7c2d</code>

<code> </code><code>computed block checksum: 0x1e</code>

<code>Total Pages Processed (Data) : 66396</code>

<code>Total Pages Marked Corrupt   : 1</code>

報告一個壞塊,Total Pages Marked Corrupt   : 1

再次查詢測試表:

<code>sys@TEST&gt;</code><code>select</code> <code>* </code><code>from</code> <code>zx.bbed;</code>

<code>    </code><code>ID </code><code>NAME</code>

<code>---------- ------------------------------------------------------------</code>

<code>     </code><code>1 zhaoxu</code>

查詢正常,因為在buffer_cache中緩存了塊,而修改的是檔案中的塊。兩個塊現在不一緻,清空buffer cache後再次查詢測試表。

<code>zx@TEST&gt;</code><code>alter</code> <code>system  flush buffer_cache;</code>

<code>System altered.</code>

<code>zx@TEST&gt;</code><code>select</code> <code>* </code><code>from</code> <code>bbed;</code>

<code>select</code> <code>* </code><code>from</code> <code>bbed</code>

<code>              </code><code>*</code>

<code>ERROR </code><code>at</code> <code>line 1:</code>

<code>ORA-01578: ORACLE data block corrupted (file # 4, block # 45844)</code>

<code>ORA-01110: data file 4: </code><code>'/u01/app/oracle/oradata/test/users01.dbf'</code>

查詢報出錯誤ORA-01578。

使用dbv檢查ASM檔案中的資料檔案,需要指定userid參數

<code>[oracle@rac1 ~]$ dbv file=+DATA/orcl/datafile/users.259.925306091 userid=sys/123456</code>

<code>DBVERIFY: Release 11.2.0.4.0 - Production </code><code>on</code> <code>Mon May 22 16:48:22 2017</code>

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

<code>DBVERIFY - Verification starting : FILE = +DATA/orcl/datafile/users.259.925306091</code>

<code>Total Pages Examined         : 640</code>

<code>Total Pages Processed (Data) : 16</code>

<code>Total Pages Processed (</code><code>Index</code><code>): 2</code>

<code>Total Pages Failing   (</code><code>Index</code><code>): 0</code>

<code>Total Pages Processed (Other): 593</code>

<code>Total Pages Empty            : 29</code>

<code>Highest block SCN            : 0 (0.0)</code>

      本文轉自hbxztc 51CTO部落格,原文連結:http://blog.51cto.com/hbxztc/1928381,如需轉載請自行聯系原作者