物理一致性和逻辑一致性检查 (DBV,rman)

物理一致性和逻辑一致性检查

DBV工具
特点:只读,不会做修改
          可以在线检查,不需要关闭数据库。
          不能检查控制文件和日志文件,而 只能检查数据文件
          可以检查ASM文件,但数据库必须open,需要通过USERID指定用户
          比如dbv file=+DG1/ORCL/datafile/system01.dbf userid=system/sys

在许多UNIX平台下,DBV要求数据文件有扩展名。如果没有(裸设备)可以通过建立链接,然后对链接文件进行操作,比如:ln -s /dev/rdsk/mydevice /tmp/mydevice.dbf

某些平台下,DBV工具不能检查超过2GB的文件,如果碰到DBV-100错误,请先检查文件大小,Metalink Bug 710888 对这个问题有描述。

可直接输入dbv 获取帮助
BLOCKSIZE,要与检查的文件的blocksize一致。缺省8192
SEGMENT_ID,可以指定要检查的段<tsn.segfile,segblock>
例子1、检查users01.dbf
[oracle@Rhel5 ~]$ dbv file=/u01/oradata/10G101/users01.dbf blocksize=8192
                            file要输入绝对路径,否则可能会报dbv-600错误
DBVERIFY: Release 10.2.0.5.0 - Production on Mon Aug 5 23:34:28 2013

Copyright (c) 1982, 2007, Oracle.  All rights reserved.

DBVERIFY - Verification starting : FILE = /u01/oradata/10G101/system01.dbf
Page 28618 is marked corrupt
Corrupt block relative dba: 0x00406fca (file 1, block 28618)
Bad check value found during dbv:
Data in bad block:
type: 6 format: 2 rdba: 0x00406fca
last change scn: 0x0000.00029ab9 seq: 0x1 flg: 0x04
spare1: 0x0 spare2: 0x0 spare3: 0x0
consistency value in tail: 0x9ab90601
check value in block header: 0xc694
computed block checksum: 0x7400


DBVERIFY - Verification complete

Total Pages Examined         : 57600
Total Pages Processed (Data) : 38088
Total Pages Failing   (Data) : 0
Total Pages Processed (Index): 7049
Total Pages Failing   (Index): 0
Total Pages Processed (Other): 1867
Total Pages Processed (Seg)  : 1
Total Pages Failing   (Seg)  : 0
Total Pages Empty            : 10595
Total Pages Marked Corrupt   : 1
Total Pages Influx           : 0
Highest block SCN            : 676674 (0.676674)


例子2、检查segment TEST
查看对象的tsn、segfile、segblock
SQL> select t.ts#,s.header_file,s.header_block
 from v$tablespace t,dba_segments s
 where s.segment_name='TEST
 and t.name=s.tablespace_name;

   TS#     HEADER_FILE   HEADER_BLOCK
----------    -----------           ------------
     0            1                      56377

[oracle@Rhel5 10G101]$ dbv userid=system/password segment_id=0.1.56377
DBVERIFY: Release 10.2.0.5.0 - Production on Mon Aug 5 23:03:54 2013

Copyright (c) 1982, 2007, Oracle.  All rights reserved.

DBVERIFY - Verification starting : SEGMENT_ID = 0.1.56377


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)  : 1s
Total Pages Failing   (Seg)  : 0
Total Pages Empty            : 0
Total Pages Marked Corrupt   : 1
Total Pages Influx           : 0 
Highest block SCN            : 666485 (0.666485)


也可以使用RMAN工具来确认位置
RMAN> backup check logical validate datafile 1;
结果查询:
SQL> select file#,block#,blocks from v$database_block_corruption;

     FILE#     BLOCK#       BLOCKS
---------- ----------            ----------
     1       28618                 1



在Oracle启动时,可以使用DBVERIFY工具来校验所有数据文件的一致性DBVERIFY是Oracle提供的一个验证工具,它可以检查数据文件中的数据块是否损坏、是否包含无效数据等问题。以下是使用DBVERIFY校验数据文件一致性的步骤: 1. 停止Oracle数据库实例。 2. 运行dbv命令,语法如下: ``` dbv file=<datafile_name> blocksize=<block_size> ``` 其中,<datafile_name>是要校验的数据文件名,<block_size>是数据块的大小。 如果要校验多个数据文件,可以使用通配符"*",例如: ``` dbv file='/u01/app/oracle/oradata/test/*.dbf' blocksize=8192 ``` 3. 执行命令后,DBVERIFY将会扫描指定的数据文件并输出校验结果。如果数据文件中存在损坏的数据块,DBVERIFY将会报告错误信息。 例如: ``` DBVERIFY: Release 12.1.0.2.0 - Production on Fri Jun 11 13:24:01 2021 Copyright (c) 1982, 2014, Oracle and/or its affiliates. All rights reserved. DBVERIFY - Verification starting : FILE = /u01/app/oracle/oradata/test/system01.dbf DBV-00100: Block, 1, marked corrupt for invalid redo application DBVERIFY - Verification complete Total Blocks Examined : 6400 Total Blocks Processed (Data) : 46 Total Blocks Failing (Data) : 1 Total Blocks Processed (Index): 0 Total Blocks Failing (Index): 0 Total Blocks Empty : 6354 Total Blocks Marked Corrupt : 1 ``` 上面的输出结果中显示,校验了system01.dbf文件,发现1个数据块有错误。DBVERIFY还会输出其他有关校验结果的统计信息,如扫描的数据块总数、数据块的类型等。 4. 根据DBVERIFY的报告,可以判断数据文件是否损坏,如果有损坏的数据块需要进行数据恢复操作,以确保数据的一致性
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值