返回顶部
首页 > 资讯 > 数据库 >Oracle的DBV工具
  • 352
分享到

Oracle的DBV工具

2024-04-02 19:04:59 352人浏览 薄情痞子
摘要

DBV(DBVERIFY)是oracle提供的一个命令行工具,它可以对数据文件物理和逻辑两种一致性检查。但是这个工具不会检查索引记录和数据记录的匹配关系,这种检查必须使用analyze validate s

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>没有缺省值

使用示例:

[oracle@rhel6 ~]$ 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属性:

zx@TEST>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:

[oracle@rhel6 ~]$ 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来检查。

创建一个测试

zx@TEST>create table bbed (id number,name varchar2(20)) tablespace users;

Table created.

zx@TEST>insert into bbed values(1,'zhaoxu');

1 row created.

zx@TEST>commit;

Commit complete.

当前数据文件没有坏块

[oracle@rhel6 ~]$ 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)

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

zx@TEST>set serveroutput on
zx@TEST>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修改块信息

[oracle@rhel6 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检查文件

[oracle@rhel6 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
再次查询测试表:

sys@TEST>select * from zx.bbed;

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

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

zx@TEST>alter system  flush buffer_cache;

System altered.

zx@TEST>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参数

[oracle@rac1 ~]$ 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

您可能感兴趣的文档:

--结束END--

本文标题: Oracle的DBV工具

本文链接: https://lsjlt.com/news/41732.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Oracle的DBV工具
    DBV(DBVERIFY)是Oracle提供的一个命令行工具,它可以对数据文件物理和逻辑两种一致性检查。但是这个工具不会检查索引记录和数据记录的匹配关系,这种检查必须使用analyze validate s...
    99+
    2024-04-02
  • DBV(DBVERIFY)工具
    DBV(DBVERIFY)是Oracle提供的一个命令行工具,它可以对数据文件物理和逻辑两种一致性检查。但是这个工具不会检查索引记录和数据记录的匹配关系,这种检查必须使用analyze validate s...
    99+
    2024-04-02
  • Oracle中DBV命令行工具如何使用
    这期内容当中小编将会给大家带来有关Oracle中DBV命令行工具如何使用,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。特点:以只读的方式打开数据文件,在检查过程中不会修改...
    99+
    2024-04-02
  • Oracle工具——csscan
    转载自:http://blog.itpub.net/4227/viewspace-706635/ 工具csscan用于检查从一个字符集转换到另一个字符集,数据库中的数据是否会产生丢失、截断等现象。 &...
    99+
    2024-04-02
  • Oracle工具sql
    查询处于锁表中的表SELECT      l.session_id SID,      ...
    99+
    2024-04-02
  • oracle常用的工具软件
    PL/SQL DevelopertoadOBJECT BROWSEREmbarcadero Rapidsql ...
    99+
    2024-04-02
  • Oracle ASM AMDU工具的使用
          Oracle 10g中, ASM磁盘组的信息需要在Mount之后才能通过内部视图查询, 如果磁盘组因为故障无法正常加载,那么信息将不可用, 这为ASM相关故障的诊...
    99+
    2024-04-02
  • oracle管理工具的介绍
    oracle管理工具的介绍(1)===================================================================sql*plus是oracle自带的工具...
    99+
    2024-04-02
  • Oracle排错工具oerr
    Oralce自带的工具集非常的多,其中oerr命令是一个不错的辅助工具,可以帮助DBA快速定位问题的缘由,并给出合理的解决方法,我们根本不需要去记有哪些ORA错误,除非那些错误已经完全和你的工作分不开。oe...
    99+
    2024-04-02
  • oracle的磁盘测试工具orion
    很久没用,拿出来上线前再用下:用法:-run [normal]||[advanced]-testname :名称和你的文件名对应-num_disks:硬盘数量-size_small: 小的随机工作量的IO的...
    99+
    2024-04-02
  • ORACLE工具之使用SQLPLUS
    SQL*Plus 是 ORACLE 数据库的命令行工具,它允许用户通过命令行界面与数据库进行交互,并执行 SQL 语句。以下是使用 ...
    99+
    2023-08-24
    oracle
  • Navicat for Oracle工具怎么连接oracle
    这篇文章给大家分享的是有关Navicat for Oracle工具怎么连接oracle的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Navicat for Oracle是一款or...
    99+
    2024-04-02
  • Oracle 11G安装bbed工具的步骤
    这篇文章主要讲解了“Oracle 11G安装bbed工具的步骤”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Oracle 11G安装bbed工具的步骤”吧!...
    99+
    2024-04-02
  • Oracle工具PL/SQL的基本语法
    在本章中,我们将学习PL/SQL的基本语法,PL/SQL是块结构语言; PL/SQL程序划分成几个部分,并在每个部分中写入逻辑代码块。每个块由三个子部分组成 - 声明部分 ...
    99+
    2024-04-02
  • Oracle连接池工具类OJDBCUtils
      Oraclejdbc.properties   driverClassName=oracle.jdbc.driver.OracleDriver url=jdbc:oracle:thin:@127.0.0.1:1521:orclusern...
    99+
    2018-05-04
    Oracle连接池工具类OJDBCUtils 数据库入门 数据库基础教程 数据库 mysql
  • 怎么安装Oracle BBED工具
    本篇内容介绍了“怎么安装Oracle BBED工具”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!BBED的...
    99+
    2024-04-02
  • Oracle OS Watcher 工具怎么用
    这篇文章主要为大家展示了“Oracle OS Watcher 工具怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Oracle OS Watcher 工具怎...
    99+
    2024-04-02
  • oracle开发工具有哪些
    oracle 提供了各种开发工具,包括数据库管理工具(sql developer、sql*plus、oracle enterprise manager)、应用程序开发工具(oracle ...
    99+
    2024-04-19
    oracle
  • oracle的环境配置-isqlplus工具介绍
    isqlplus工具介绍:维护的时候用来查询视图或者执行DML使用,界面直观,但是是无法执行命令的,比如Oracle的启动和关闭1、启动服务[oracle@oracle3 ~]$ isqlplusctl s...
    99+
    2024-04-02
  • Oracle 测试工具 Swingbench 的使用方法
    1、安装 JDK 1.82、安装 Wingbench,下载 解压即可3、初始化模式 SOE 的数据,双击 D:\swingbench\winbin\oewizard 24、执行测试,双击D:\swingbe...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作