盛夏的果实 发表于 2021-7-10 13:27:16

DBVERIFY(DBV)坏块的检测工具 (Doc ID 35512.1)

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

[*]以只读的方式打开数据文件,在检查过程中不会修改数据文件的内容。
[*]可以在线检查数据文件,而不需要关闭数据库。
[*]DBV只会检查数据块的正确性,但不会关系数据块是否属于哪个对象。
  dbv help=y
参数含义缺省值FILE要检查的数据文件名没有缺省值START检查起始数据块号数据文件的第一个数据块END检查的最后一个数据块号数据文件的最后一个数据块BLOCKSIZE数据块大小,这个值要和数据库的DB_BLOCK_SIZE参数值一致缺省值8192LOGFILE检查结果日志文件没有缺省值FEEDBAK显示进度0PARFILE参数文件名没有缺省值USERID用户名、密码没有缺省值SEGMENT_ID段ID,参数格式<tsn.segfile.segblock>没有缺省值二、测试实验(db version:19.3.0.0,ASM) 1、检查ASM实例数据文件
$ dbv file=+DATA/ORCL/DATAFILE/SYSAUX.258.1067243075

DBVERIFY: Release 19.0.0.0.0 - Production on Thu Mar 18 07:15:40 2021

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

DBVERIFY - Verification starting : FILE = +DATA/ORCL/DATAFILE/SYSAUX.258.1067243075


DBVERIFY - Verification complete

Total Pages Examined         : 69120
Total Pages Processed (Data) : 5437
Total Pages Failing   (Data) : 0
Total Pages Processed (Index): 2684
Total Pages Failing   (Index): 0
Total Pages Processed (Lob): 25350

2、指定BLOCKSIZE检测数据文件,blocksize=8192kb
--获取数据库db_block_size
SQL> show parameter db_block_size

NAME                                 TYPE      VALUE
------------------------------------ ----------- ------------------------------
db_block_size                        integer   8192

--获取数据文件号
SQL> select file#,name from v$datafile;

   FILE# NAME
---------- --------------------------------------------------------------------------------
         1 +DATA/ORCL/DATAFILE/system.274.1067312029
         3 +DATA/ORCL/DATAFILE/sysaux.275.1067312063
         4 +DATA/ORCL/DATAFILE/undotbs1.276.1067312079
         5 +DATA/ORCL/86B637B62FE07A65E053F706E80A27CA/DATAFILE/system.282.1067312545
         6 +DATA/ORCL/86B637B62FE07A65E053F706E80A27CA/DATAFILE/sysaux.283.1067312545
         7 +DATA/ORCL/DATAFILE/users.277.1067312079
         8 +DATA/ORCL/86B637B62FE07A65E053F706E80A27CA/DATAFILE/undotbs1.284.1067312545
         9 +DATA/ORCL/DATAFILE/undotbs2.286.1067312997

8 rows selected.

--获取数据文件1的END
SQL> select bytes/8192 from v$datafile where file#=1;

BYTES/8192
----------
    113920

--检查数据文件是否有坏块
$ dbv file=+DATA/ORCL/DATAFILE/system.274.1067312029 blocksize=8192 end=113920

DBVERIFY: Release 19.0.0.0.0 - Production on Thu Mar 18 07:28:51 2021

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

DBVERIFY - Verification starting : FILE = +DATA/ORCL/DATAFILE/system.274.1067312029


DBVERIFY - Verification complete

Total Pages Examined         : 113920
Total Pages Processed (Data) : 79434
Total Pages Failing   (Data) : 0
Total Pages Processed (Index): 12737
Total Pages Failing   (Index): 0
Total Pages Processed (Other): 5111
Total Pages Processed (Seg): 1
Total Pages Failing   (Seg): 0
Total Pages Empty            : 16638
Total Pages Marked Corrupt   : 0
Total Pages Influx         : 0
Total Pages Encrypted      : 0
Highest block SCN            : 2369647 (0.2369647)


3、检查控制文件,blocksize=16384kb
--检测控制文件是否坏块
--不指定bolcksize会报错
$ dbv file=+DATA/ORCL/CONTROLFILE/current.278.1067312147

DBVERIFY: Release 19.0.0.0.0 - Production on Thu Mar 18 08:23:06 2021

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

DBVERIFY - Verification starting : FILE = +DATA/ORCL/CONTROLFILE/current.278.1067312147

DBV-00111: OCI failure (4409) (ORA-19501: read error on file "+DATA/ORCL/CONTROLFILE/current.278.1067312147", block number 1 (block size=8192)
ORA-17507: I/O request sizeis not a multiple of logical block size.
ORA-06512: at "SYS.DBMS_DBVERIFY", line 24
ORA-06512: at line 1
)

--查看控制文件的blocksize为16K
$ dbfsize Current.261.1067243211

Database file: Current.261.1067243211
Database file type: file system
Database file size: 1202 16384 byte blocks


--指定blocksize为16K
$ dbv file=+DATA/ORCL/CONTROLFILE/current.278.1067312147 blocksize=16384

DBVERIFY: Release 19.0.0.0.0 - Production on Thu Mar 18 08:24:03 2021

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

DBVERIFY - Verification starting : FILE = +DATA/ORCL/CONTROLFILE/current.278.1067312147


DBVERIFY - Verification complete

Total Pages Examined         : 1202
Total Pages Processed (Data) : 0
Total Pages Failing   (Data) : 0
Total Pages Processed (Index): 0
Total Pages Failing   (Index): 0
Total Pages Processed (Other): 85
Total Pages Processed (Seg): 0
Total Pages Failing   (Seg): 0
Total Pages Empty            : 1117
Total Pages Marked Corrupt   : 0
Total Pages Influx         : 0
Total Pages Encrypted      : 0
Highest block SCN            : 1382 (0.1382)

4、检查单独的Segment
--查看对象的tsn,segfile,segblock属性:
select t.ts#,s.header_file,s.header_block
from v$tablespace t,dba_segments s
where s.segment_name='LUCIFER'
4and t.name=s.tablespace_name;

       TS# HEADER_FILE HEADER_BLOCK
---------- ----------- ------------
         0          10      33600

--检查segment是否坏块
$ dbv userid=lucifer/lucifer@pdb01 segment_id=0.10.33600

DBVERIFY: Release 19.0.0.0.0 - Production on Thu Mar 18 08:25:35 2021

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

DBVERIFY - Verification starting : SEGMENT_ID = 0.10.33600

DBV-00600: Fatal Error -

-- 5、检查log文件(redo和arch)blocksize=512kb
$ dbv file=+DATA/ORCL/ONLINELOG/group_1.280.1067312151

DBVERIFY: Release 19.0.0.0.0 - Production on Thu Mar 18 08:30:58 2021

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

DBVERIFY - Verification starting : FILE = +DATA/ORCL/ONLINELOG/group_1.280.1067312151
Segmentation fault (core dumped)
--将asm中redolog文件复制一份出来
$ asmcmd -p
ASMCMD [+] > cp +DATA/ORCL/ONLINELOG/group_1.280.1067312151 /home/grid
copying +DATA/ORCL/ONLINELOG/group_1.280.1067312151 -> /home/grid/group_1.280.1067312151
ASMCMD [+] > exit
$ ls
Current.261.1067243211group_1.280.1067312151
--检查redo日志文件
$ dbv file=group_1.280.1067312151

DBVERIFY: Release 19.0.0.0.0 - Production on Thu Mar 18 08:32:20 2021

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


DBV-00103: Specified BLOCKSIZE (8192) differs from actual (512)

--查看redo log的blocksize为512k
$ dbv file=group_1.280.1067312151

DBVERIFY: Release 19.0.0.0.0 - Production on Thu Mar 18 08:32:20 2021

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


DBV-00103: Specified BLOCKSIZE (8192) differs from actual (512)
$ dbfsize group_1.280.1067312151

Database file: group_1.280.1067312151
Database file type: file system
Database file size: 409600 512 byte blocks

--$ dbv file=group_1.280.1067312151 blocksize=512

DBVERIFY - Verification complete

Total Pages Examined         : 409600
Total Pages Processed (Data) : 0
Total Pages Failing   (Data) : 0
Total Pages Processed (Index): 0
Total Pages Failing   (Index): 0
Total Pages Processed (Other): 0
Total Pages Processed (Seg): 0
Total Pages Failing   (Seg): 0
Total Pages Empty            : 0
Total Pages Marked Corrupt   : 409600
Total Pages Influx         : 190957
Total Pages Encrypted      : 0
Highest block SCN            : 0 (0.0)

--查看归档日志
$ dbv file=thread_1_seq_8.295.1067503735 blocksize=512 logfile=archdbv.log feedback=100

$ cat archdbv.log

DBVERIFY - Verification complete

Total Pages Examined         : 42293
Total Pages Processed (Data) : 0
Total Pages Failing   (Data) : 0
Total Pages Processed (Index): 0
Total Pages Failing   (Index): 0
Total Pages Processed (Other): 0
Total Pages Processed (Seg): 0
Total Pages Failing   (Seg): 0
Total Pages Empty            : 0
Total Pages Marked Corrupt   : 42293
Total Pages Influx         : 12885
Total Pages Encrypted      : 0
Highest block SCN            : 0 (0.0)
 


  
文档来源:51CTO技术博客https://blog.51cto.com/luciferliu/3029530
页: [1]
查看完整版本: DBVERIFY(DBV)坏块的检测工具 (Doc ID 35512.1)