博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
检测ORACLE方法汇总数据块损坏
阅读量:6911 次
发布时间:2019-06-27

本文共 6227 字,大约阅读时间需要 20 分钟。

1:使用初始化参数

使用初始化参数db_block_checksum\db_block_checking能够设置数据库对块的物理一致性和逻辑一致性检查。

Db_block_checksum:物理一致性检查。默认开启。

始终对system表空间数据进行检查。假设开启还会对日志进行检查,开启后会有12%的性能影响。建议开启。

Db_block_checking:逻辑一致性检查,默认未开启。始终对system表空间进行检查,假设开启会有110%的性能影响。DML越频繁,性能影响越大。不建议开启。

有关该參数的具体内容能够參考:

 

2:使用dbv工具

使用dbv能够进行物理和逻辑一致性检查,可是不会检測表数据和索引数据的匹配关系。使用该工具有下面特点:

仅仅读方式打开数据文件

能够在线检查数据文件,数据库无需关闭

不能够检測控制文件和日志文件

能够检測asm文件

有时文件名须要有后缀名,而且有时不能够检測超过2G大小的文件

 

3:使用analyze命令

   语法格式:analyze table validate structure cascade online (offline).

该命令会同一时候进行物理和逻辑检查,同一时候还能够进行表数据和索引数据的匹配性检查,检查分区表的记录是否在正确的分区中,检測结果会存储在trace文件里。

假设没有使用cascadekeyword。则仅仅会进行表数据的检測。使用cascade后会进行表数据和索引数据的检測。

假设使用了onlinekeyword,则能够对表数据进行在线检查。此时不会对表加入锁,DML语句能够继续进行。假设使用了offlinekeyword,则会对表加锁。此时用户不能对该表进行改动操作。

假设须要检測分区表记录是否在正确的分区内,能够使用例如以下语句:

Anlyze table table_name validte structure into invalid_rows.

使用该命令前,请使用utlvalid.sql 脚本创建对应的invalid_rows表。

 

4:使用rman工具

使用rman备份工具时,oracle会将数据先读入读缓冲区。然后将数据写入写缓冲区,最后写入磁盘,在从读缓冲区转移到写缓冲区时。rman工具会进行数据一致性检測。

语法格式:backup validate database.

使用backup validate 命令会对数据文件进行物理一致性检測(前提是db_block_checksum启用), 此时并不会生成备份文件。如:

RMAN> backup validate database; Starting backup at 2014-11-05 15:44:21using channel ORA_DISK_1channel ORA_DISK_1: starting full datafile backupsetchannel ORA_DISK_1: specifying datafile(s) in backupsetinput datafile fno=00001 name=/home/app/oraten/oradata/oraten/system01.dbfinput datafile fno=00003 name=/home/app/oraten/oradata/oraten/sysaux01.dbfinput datafile fno=00002 name=/home/app/oraten/oradata/oraten/undotbs01.dbfinput datafile fno=00005 name=/home/app/oraten/oradata/oraten/test01.dbfinput datafile fno=00004 name=/home/app/oraten/oradata/oraten/users01.dbfchannel ORA_DISK_1: backup set complete, elapsed time: 00:00:01channel ORA_DISK_1: starting full datafile backupsetchannel ORA_DISK_1: specifying datafile(s) in backupsetincluding current control file in backupsetincluding current SPFILE in backupsetchannel ORA_DISK_1: backup set complete, elapsed time: 00:00:01Finished backup at 2014-11-05 15:44:23 RMAN> list backup;  RMAN>

我们也能够加入check logical选项,以便rman进行逻辑一致性检測。

注意:check logical是命令选项,假设单独使用check logical会生成备份:

RMAN> backup check logical validate database; Starting backup at 2014-11-05 15:45:59using channel ORA_DISK_1channel ORA_DISK_1: starting full datafile backupsetchannel ORA_DISK_1: specifying datafile(s) in backupsetinput datafile fno=00001 name=/home/app/oraten/oradata/oraten/system01.dbfinput datafile fno=00003 name=/home/app/oraten/oradata/oraten/sysaux01.dbfinput datafile fno=00002 name=/home/app/oraten/oradata/oraten/undotbs01.dbfinput datafile fno=00005 name=/home/app/oraten/oradata/oraten/test01.dbfinput datafile fno=00004 name=/home/app/oraten/oradata/oraten/users01.dbfchannel ORA_DISK_1: backup set complete, elapsed time: 00:00:03channel ORA_DISK_1: starting full datafile backupsetchannel ORA_DISK_1: specifying datafile(s) in backupsetincluding current control file in backupsetincluding current SPFILE in backupsetchannel ORA_DISK_1: backup set complete, elapsed time: 00:00:01Finished backup at 2014-11-05 15:46:04 RMAN> list backup;  RMAN> backup check logical database; Starting backup at 2014-11-05 15:46:14using channel ORA_DISK_1channel ORA_DISK_1: starting full datafile backupsetchannel ORA_DISK_1: specifying datafile(s) in backupsetinput datafile fno=00001 name=/home/app/oraten/oradata/oraten/system01.dbfinput datafile fno=00003 name=/home/app/oraten/oradata/oraten/sysaux01.dbfinput datafile fno=00002 name=/home/app/oraten/oradata/oraten/undotbs01.dbfinput datafile fno=00005 name=/home/app/oraten/oradata/oraten/test01.dbfinput datafile fno=00004 name=/home/app/oraten/oradata/oraten/users01.dbfchannel ORA_DISK_1: starting piece 1 at 2014-11-05 15:46:14channel ORA_DISK_1: finished piece 1 at 2014-11-05 15:46:39piece handle=/home/app/oraten/flash_recovery_area/ORATEN/backupset/2014_11_05/o1_mf_nnndf_TAG20141105T154614_b5mog6kr_.bkp tag=TAG20141105T154614 comment=NONEchannel ORA_DISK_1: backup set complete, elapsed time: 00:00:25channel ORA_DISK_1: starting full datafile backupsetchannel ORA_DISK_1: specifying datafile(s) in backupsetincluding current control file in backupsetincluding current SPFILE in backupsetchannel ORA_DISK_1: starting piece 1 at 2014-11-05 15:46:40channel ORA_DISK_1: finished piece 1 at 2014-11-05 15:46:41piece handle=/home/app/oraten/flash_recovery_area/ORATEN/backupset/2014_11_05/o1_mf_ncsnf_TAG20141105T154614_b5moh030_.bkp tag=TAG20141105T154614 comment=NONEchannel ORA_DISK_1: backup set complete, elapsed time: 00:00:02Finished backup at 2014-11-05 15:46:41 List of Backup Sets=================== BS Key  Type LV Size       Device Type Elapsed Time Completion Time    ------- ---- -- ---------- ----------- ------------ -------------------59      Full    545.84M    DISK        00:00:17     2014-11-05 15:46:31        BP Key: 41   Status: AVAILABLE  Compressed: NO  Tag: TAG20141105T154614        Piece Name: /home/app/oraten/flash_recovery_area/ORATEN/backupset/2014_11_05/o1_mf_nnndf_TAG20141105T154614_b5mog6kr_.bkp  List of Datafiles in backup set 59  File LV Type Ckp SCN    Ckp Time            Name  ---- -- ---- ---------- ------------------- ----  1       Full 870906     2014-11-05 15:46:14 /home/app/oraten/oradata/oraten/system01.dbf  2       Full 870906     2014-11-05 15:46:14 /home/app/oraten/oradata/oraten/undotbs01.dbf  3       Full 870906     2014-11-05 15:46:14 /home/app/oraten/oradata/oraten/sysaux01.dbf  4       Full 870906     2014-11-05 15:46:14 /home/app/oraten/oradata/oraten/users01.dbf  5       Full 870906     2014-11-05 15:46:14 /home/app/oraten/oradata/oraten/test01.dbf BS Key  Type LV Size       Device Type Elapsed Time Completion Time    ------- ---- -- ---------- ----------- ------------ -------------------60      Full    6.80M      DISK        00:00:01     2014-11-05 15:46:40        BP Key: 42   Status: AVAILABLE  Compressed: NO  Tag: TAG20141105T154614        Piece Name: /home/app/oraten/flash_recovery_area/ORATEN/backupset/2014_11_05/o1_mf_ncsnf_TAG20141105T154614_b5moh030_.bkp  Control File Included: Ckp SCN: 870915       Ckp time: 2014-11-05 15:46:39  SPFILE Included: Modification time: 2014-11-05 15:16:33 

关于rman备份与恢复的验证,能够參照:

 

 

5:使用dbms_repair

关于dbms_repaire包的使用,请參见:

版权声明:本文博客原创文章。博客,未经同意,不得转载。

你可能感兴趣的文章
Linux下修改Mysql的用户(root)的密码
查看>>
20个java异常处理最佳实践
查看>>
centos架设pptp服务:并测试windos客户端、Linux客户端!
查看>>
【c#】BackgroundWorker类的使用方法
查看>>
【NetApp】启用smb2.0
查看>>
001作业题
查看>>
关于实习
查看>>
叠加等边三角形
查看>>
【对拍√】
查看>>
重载,继承,重写,多态的区别
查看>>
NUnit笔记
查看>>
maven添加sqlserver的jdbc驱动包
查看>>
POJ 1426 Find The Multiple
查看>>
WPF入门教程系列五——Window 介绍
查看>>
数字图像处理中所用数学工具4---集合、逻辑操作与模糊集合
查看>>
网页换肤
查看>>
[BZOJ3751/NOIP2014]解方程
查看>>
【Java例题】3.5 级数之和
查看>>
silverlight多国语言研究
查看>>
开发--省级三联动,简单的代码,但是功能不差
查看>>