Oracle的DBV命令行工具用法详解

网友投稿 1597 2023-05-02

***的DBV命令行工具用法详解

***的DBV命令行工具用法详解

DBV(DBVERIFY)是***提供的一个命令行工具,它可以对数据文件物理和逻辑两种一致性检查。但是这个工具不会检查索引记录和数据记录的匹配关系,这种检查必须使用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=。可以在v$datafile视图中用bytes字段除以块大小来获得END值。

参数                                        含义                                                                                                        缺省值

FILE                                       要检查的数据文件名                                                                              没有缺省值

START                               检查起始数据块号                                                                           数据文件的***个数据块

END                                       检查的***一个数据块号                                                                   数据文件的***一个数据块

BLOCKSIZE                       数据块大小,这个值要和数据库的DB_BLOCK_SIZE参数值一致            缺省值8192

LOGFILE                               检查结果日志文件                                                                            没有缺省值

FEEDBAK                       显示进度                                                                                            0

PARFILE                               参数文件名                                                                                         没有缺省值

USERID                               用户名、密码                                                                                没有缺省值

SEGMENT_ID                       段ID,参数格式                                          没有缺省值

使用示例:

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

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

查看对象的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:

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

创建一个测试表

当前数据文件没有坏块

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

使用bbed修改块信息

[***@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, *** and/or its affiliates.  All rights reserved.    ************* !!! For *** Internal Use only !!! ***************    BBED> set dba 4,45844         DBA             0x0100b314 (16823060 4,45844)    BBED> find /c zhaoxu  File: /u01/app/***/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/***/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/***/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/***/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检查文件

报告一个坏块,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/***/oradata/test/users01.dbf'

查询报出错误ORA-01578。

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

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:TiDB 4.0 新特性尝鲜指南
下一篇:许多SQL性能问题来自于“不必要的强制性工作”
相关文章