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 显示进度 0
PARFILE 参数文件名 没有缺省值
USERID 用户名、密码 没有缺省值
SEGMENT_ID 段ID,参数格式<tsn.segfile.segblock> 没有缺省值

使用示例:

[[email protected] ~]$ dbv file=/u01/app/oracle/oradata/test/users01.dbf

DBVERIFY: Release 11.2.0.1.0 - Production on Mon May 22 16:42:26 2017

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

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

DBVERIFY - Verification complete

Total Pages Examined         : 155520
Total Pages Processed (Data) : 144530
Total Pages Failing   (Data) : 0
Total Pages Processed (Index): 52
Total Pages Failing   (Index): 0
Total Pages Processed (Other): 1248
Total Pages Processed (Seg)  : 0
Total Pages Failing   (Seg)  : 0
Total Pages Empty            : 9690
Total Pages Marked Corrupt   : 0
Total Pages Influx           : 0
Total Pages Encrypted        : 0
Highest block SCN            : 3559792 (0.3559792)

这个工具报告使用的是page作为单位,含义和data block相同。从上面的检查结果Total Pages Marked Corrupt   : 0可以看出文件没有坏块。

除了检查数据文件,这个工具还允许检查单独的Segment,这时参数值的格式为<tsn.segfile.segblock>

查看对象的tsn,segfile,segblock属性:

[email protected]>select t.ts#,s.header_file,s.header_block
  2  from v$tablespace t,dba_segments s
  3  where s.segment_name=‘T‘
  4  and t.name=s.tablespace_name;

       TS# HEADER_FILE HEADER_BLOCK
---------- ----------- ------------
         4           4        45834

从上面的查询结果可行参数值为4.4.45834。检查Segment:

[[email protected] ~]$ dbv userid=system/123456 segment_id=4.4.45834

DBVERIFY: Release 11.2.0.1.0 - Production on Mon May 22 20:58:33 2017

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

DBVERIFY - Verification starting : SEGMENT_ID = 4.4.45834

DBVERIFY - Verification complete

Total Pages Examined         : 8
Total Pages Processed (Data) : 5
Total Pages Failing   (Data) : 0
Total Pages Processed (Index): 0
Total Pages Failing   (Index): 0
Total Pages Processed (Other): 2
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            : 3518579 (0.3518579)

下面人为创造一个坏块,用dbv来检查。

创建一个测试表

[email protected]>create table bbed (id number,name varchar2(20)) tablespace users;

Table created.

[email protected]>insert into bbed values(1,‘zhaoxu‘);

1 row created.

[email protected]>commit;

Commit complete.

当前数据文件没有坏块

[[email protected] ~]$ dbv file=/u01/app/oracle/oradata/test/users01.dbf

DBVERIFY: Release 11.2.0.1.0 - Production on Mon May 22 21:03:40 2017

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

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

DBVERIFY - Verification complete

Total Pages Examined         : 155520
Total Pages Processed (Data) : 66397
Total Pages Failing   (Data) : 0
Total Pages Processed (Index): 52
Total Pages Failing   (Index): 0
Total Pages Processed (Other): 88898
Total Pages Processed (Seg)  : 0
Total Pages Failing   (Seg)  : 0
Total Pages Empty            : 173
Total Pages Marked Corrupt   : 0
Total Pages Influx           : 0
Total Pages Encrypted        : 0
Highest block SCN            : 3764775 (0.3764775)

获取表在文件中的存储信息

[email protected]>set serveroutput on
[email protected]>declare rfno number;
  2  rtype number;
  3  ono number;
  4  blkno number;
  5  rowno number;
  6  rid varchar2(30);
  7  begin
  8  select rowid into rid from bbed;
  9  dbms_rowid.rowid_info(ROWID_IN=>rid,RELATIVE_FNO=>rfno,BLOCK_NUMBER=>blkno,ROW_NUMBER=>rowno,ROWID_TYPE=>rtype,OBJECT_NUMBER=>ono);
 10  dbms_output.put_line(rfno||‘,‘||blkno||‘,‘||rowno);
 11  end;
 12  /
4,45844,0

PL/SQL procedure successfully completed.

使用bbed修改块信息

[[email protected] bbed]$ bbed parfile=bbed.par
Password: 

BBED: Release 2.0.0.0.0 - Limited Production on Mon May 22 21:17:18 2017

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

************* !!! For Oracle Internal Use only !!! ***************

BBED> set dba 4,45844
        DBA             0x0100b314 (16823060 4,45844)

BBED> find /c zhaoxu
 File: /u01/app/oracle/oradata/test/users01.dbf (4)
 Block: 45844            Offsets: 8182 to 8191           Dba:0x0100b314
------------------------------------------------------------------------
 7a68616f 78750106 5873 

 <32 bytes per line>

BBED> dump /v dba 4,45844 offset 8182 count 32
 File: /u01/app/oracle/oradata/test/users01.dbf (4)
 Block: 45844   Offsets: 8182 to 8191  Dba:0x0100b314
-------------------------------------------------------
 7a68616f 78750106 5873              l zhaoxu..Xs

 <16 bytes per line>

BBED> modify 100 dba 4,45844
Warning: contents of previous BIFILE will be lost. Proceed? (Y/N) y
 File: /u01/app/oracle/oradata/test/users01.dbf (4)
 Block: 45844            Offsets: 8182 to 8191           Dba:0x0100b314
------------------------------------------------------------------------
 6468616f 78750106 5873 

 <32 bytes per line>

BBED> dump /v dba 4,45844 offset 8182 count 32
 File: /u01/app/oracle/oradata/test/users01.dbf (4)
 Block: 45844   Offsets: 8182 to 8191  Dba:0x0100b314
-------------------------------------------------------
 6468616f 78750106 5873              l dhaoxu..Xs

 <16 bytes per line>

BBED> exit

再次使用dbv检查文件

[[email protected] bbed]$ dbv file=/u01/app/oracle/oradata/test/users01.dbf

DBVERIFY: Release 11.2.0.1.0 - Production on Mon May 22 21:18:46 2017

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

DBVERIFY - Verification starting : FILE = /u01/app/oracle/oradata/test/users01.dbf
Page 45844 is marked corrupt
Corrupt block relative dba: 0x0100b314 (file 4, block 45844)
Bad check value found during dbv: 
Data in bad block:
 type: 6 format: 2 rdba: 0x0100b314
 last change scn: 0x0000.00397358 seq: 0x1 flg: 0x04
 spare1: 0x0 spare2: 0x0 spare3: 0x0
 consistency value in tail: 0x73580601
 check value in block header: 0x7c2d
 computed block checksum: 0x1e

DBVERIFY - Verification complete

Total Pages Examined         : 155520
Total Pages Processed (Data) : 66396
Total Pages Failing   (Data) : 0
Total Pages Processed (Index): 52
Total Pages Failing   (Index): 0
Total Pages Processed (Other): 88898
Total Pages Processed (Seg)  : 0
Total Pages Failing   (Seg)  : 0
Total Pages Empty            : 173
Total Pages Marked Corrupt   : 1
Total Pages Influx           : 0
Total Pages Encrypted        : 0
Highest block SCN            : 3764775 (0.3764775)

报告一个坏块,Total Pages Marked Corrupt   : 1
再次查询测试表:

[email protected]>select * from zx.bbed;

	ID NAME
---------- ------------------------------------------------------------
	 1 zhaoxu

查询正常,因为在buffer_cache中缓存了块,而修改的是文件中的块。两个块现在不一致,清空buffer cache后再次查询测试表。

[email protected]>alter system  flush buffer_cache;

System altered.

[email protected]>select * from bbed;
select * from bbed
              *
ERROR at line 1:
ORA-01578: ORACLE data block corrupted (file # 4, block # 45844)
ORA-01110: data file 4: ‘/u01/app/oracle/oradata/test/users01.dbf‘

查询报出错误ORA-01578。

使用dbv检查ASM文件中的数据文件,需要指定userid参数

[[email protected] ~]$ dbv file=+DATA/orcl/datafile/users.259.925306091 userid=sys/123456

DBVERIFY: Release 11.2.0.4.0 - Production on Mon May 22 16:48:22 2017

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

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

DBVERIFY - Verification complete

Total Pages Examined         : 640
Total Pages Processed (Data) : 16
Total Pages Failing   (Data) : 0
Total Pages Processed (Index): 2
Total Pages Failing   (Index): 0
Total Pages Processed (Other): 593
Total Pages Processed (Seg)  : 0
Total Pages Failing   (Seg)  : 0
Total Pages Empty            : 29
Total Pages Marked Corrupt   : 0
Total Pages Influx           : 0
Total Pages Encrypted        : 0
Highest block SCN            : 0 (0.0)

参考:《大话Oracle RAC》

MOS文档:文档 ID 35512.1

时间: 2024-10-22 06:51:46

Oracle的DBV工具的相关文章

Oracle Wrapped 解码工具

搞Oracle开发的朋友有福了! Oracle中的Wrap 功能是为了不让别人看到函数/存储过程的SQL源码的明文, 作为技术宅,有的时候想看源码但是看不到的那种心情是可以理解的, 发一个简单易用界面友好交互性强的 Oracle wrapped 解码工具(^0^ 自夸一下,开个玩笑) http://files.cnblogs.com/dint/DfUnWraper.zip 主要是参考这两个帖子中作者关于wrapped原理的说明 http://www.itpub.net/thread-115423

ORACLE导入导出工具的使用

ORACLE导出工具exp的使用: 1.将数据库TEST(远程的数据库必须为连接标志符)完全导出,用户名system,密码manager,导出到D:\daochu.dmp中: exp system/[email protected] file=d:\daochu.dmp full=y 2.将数据库中system用户与sys用户的表导出: exp system/[email protected] file=d:\daochu.dmp owner=(system,sys) 3.将数据库中的表tabl

Oracle 通过ADR工具 收集ORA-600错误信息

 问题描述: 2014-06-10 在点检数据库预警文件时,出现Ora -00600 错误,并且Rman L1 备份失败,查询相关资料,得知是Bug:9835218.于是,提SR寻求Oracle 官方技术支持. Oracle回复如下: Your Service Request has been submitted as anORA-600/ORA-7445 issue based on the problem type you chose when logging the SR. Additio

Oracle简易界面工具 (Oracle 10g, Oracle 11g)

Oracle简易界面工具 背景:偶在远程机上干活,须要调用到 Oracle 11gserver的数据,远程机上已安装Oracle client, 但 sql plus 和 sql developer 及 pl sql developer 都不能用 (DBA折腾几天都没解决).偶 有server的ip, oracleusername及password:知道部分表名及字段名. 因时间紧,偶仅仅好自己写一个简易的界面工具来应急. 演示效果:     演示下载: http://pan.baidu.com

Oracle性能分析工具介绍及使用

oracle数据库级别优化分析工具介绍 当我们对数据库优化诊断时,需要收集相应的信息以供参考,从个人的使用经验来说,这种统计数据分为两大类 一类是数据库级别的统计信息二类是os级别的统计信息 下面就分别介绍在不同的级别下,常用什么工具来收集信息帮助优化诊断 首先是oracle数据库级别优化分析工具介绍 目录: 1.statspack2.ASH3.AWR4.ORACLE EXPLAIN PLAN的总结(查询sql的执行计划)   a.autotrace   b.explain的使用 1.stats

[Oracle] - 性能优化工具(5) - AWRSQL

在AWR中定位到问题SQL语句后想要了解该SQL statement的详细运行计划,于是就用AWR报告中得到的SQL ID去V$SQL等几个动态性能视图中查询,但发现V$SQL或V$SQL_PLAN视图都已经找不到相应SQL ID的记录,一般来说这些语句已经从shared pool共享池中被替换出去了. 这个时候我们能够尝试使用DBMS_XPLAN.DISPLAY_AWR存储过程来将Oracle Automatic Workload Repository自己主动负载仓库中记录的SQL语句相关信息

[Oracle] - 性能优化工具(1) - AWR

AWR快照 默认情况下,Oracle每隔一小时会自己主动产生一个快照,保存近期8天的快照. 我们能够通过例如以下语句获得产生快照的时间间隔和保存的天数: [email protected](lx15)> select SNAP_INTERVAL,RETENTION from dba_hist_wr_control; SNAP_INTERVAL RETENTION -------------------------------------------------------------------

Oracle SID爆破工具SidGuess

在Oracle中,SID是System IDentifier的缩写.SID是一个数据库的唯一标识符.当用户希望远程连接Oracle数据库时,则需要知道SID.用户名.密码及服务器的IP地址.SidGuess就是一款根据字典爆破Oracle SID的工具.该工具的破解比较慢,每秒80-100个.该工具非常简单,格式如下: sidguess -i 服务器IP  -d SID字典文件

[Oracle] - 性能优化工具(3) - ADDM

ADDM 通过检查和分析AWR获取的数据来判断Oracle数据库中可能的问题,并给出优化建议. 获取ADDM的方法如下: @?/rdbms/admin/addmrpt.sql 下面可以看一个例子: --第一步:创建测试用的表 drop table t cascade constraints purge; create table t AS SELECT * FROM dba_objects ; --第二步:快照 exec dbms_workload_repository.create_snaps