重庆思庄Oracle、Redhat认证学习论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 1289|回复: 0
打印 上一主题 下一主题

[工具] DBV命令行工具检测坏块

[复制链接]
跳转到指定楼层
楼主
发表于 2022-8-7 16:35:37 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 刘泽宇 于 2022-8-7 16:36 编辑

一,介绍
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@oracle01 oracle01]$ dbv file=test01.dbf
--最好是绝对路径,这里是进入到对应目录下,所以用相对路径
DBVERIFY: Release 11.2.0.4.0 - Production on Mon May 13 15:21:42 2019

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

DBVERIFY - Verification starting : FILE = /u01/app/oracle/oradata/oracle01/test01.dbf

DBVERIFY - Verification complete

Total Pages Examined         : 1280 --( 检查总页数)
Total Pages Processed (Data) : 5    --(处理的总页数(数据))
Total Pages Failing   (Data) : 0 --(总页数失败(数据))
Total Pages Processed (Index): 0 --(处理的总页数(索引))
Total Pages Failing   (Index): 0 --(总页面失败(索引))
Total Pages Processed (Other): 136 --(处理的总页数(其他))
Total Pages Processed (Seg)  : 0 --(处理的总页数(Seg))
Total Pages Failing   (Seg)  : 0 --(总页数失败(Seg)
Total Pages Empty            : 1139 --(总页数空)
Total Pages Marked Corrupt   : 0 --(总页数标记为损坏)
Total Pages Influx           : 0 --(总页面数量)
Total Pages Encrypted        : 0 --(加密总页数)
Highest block SCN            : 11638862 (0.11638862) --(最高块SCN)
  这个工具报告使用的是page作为单位,含义和data block相同。从上面的检查结果Total Pages Marked Corrupt   : 0可以看出文件没有坏块。

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

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

SQL> select t.ts#,s.header_file,s.header_block
from v$tablespace t,dba_segments s
where s.segment_name='T'
and t.name=s.tablespace_name;   2    3    4

     0         1          96544
从上面的查询结果可行参数值为0.1.96544。检查Segment:

[oracle@oracle01 oracle01]$ dbv userid=system/123456 segment_id=0.1.96544

DBVERIFY: Release 11.2.0.4.0 - Production on Mon May 13 15:27:53 2019

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

DBVERIFY - Verification starting : SEGMENT_ID = 0.1.96544

DBVERIFY - Verification complete

Total Pages Examined         : 2
Total Pages Processed (Data) : 1
Total Pages Failing   (Data) : 0
Total Pages Processed (Index): 0
Total Pages Failing   (Index): 0
Total Pages Processed (Other): 0
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            : 11645088 (0.11645088)
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 支持支持 反对反对
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|手机版|小黑屋|重庆思庄Oracle、Redhat认证学习论坛 ( 渝ICP备12004239号-4 )

GMT+8, 2024-5-4 12:21 , Processed in 0.093128 second(s), 20 queries .

重庆思庄学习中心论坛-重庆思庄科技有限公司论坛

© 2001-2020

快速回复 返回顶部 返回列表