首页 > 数据库 >通过 RMAN 备份 修复 Oracle 坏块的操作案例

通过 RMAN 备份 修复 Oracle 坏块的操作案例

时间:2023-12-23 20:31:54浏览次数:40  
标签:blocks Pages Oracle file 坏块 RMAN Total id block

Oracle rman备份报错,提示数据文件有坏块,自己查看alert并无报错,说明还没有影响到业务。。

根据报错检查确认

[oracle@xx02 ~]$ dbv  file='+DATAC1/xxxxdb/datafile/xx_tbs.3223.1044115207' blocksize=8192 userid=sys/xxxxxxx

DBVERIFY: Release 11.2.0.4.0 - Production on Mon Nov 22 09:45:59 2021

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

DBVERIFY - Verification starting : FILE = +DATAC1/xxxxdb/datafile/xx_tbs.3223.1044115207
Page 8212 is marked corrupt
Corrupt block relative dba: 0xaa402014 (file 681, block 8212)
Bad header found during dbv: 
Data in bad block:
 type: 122 format: 2 rdba: 0xbadfda7a
 last change scn: 0xda7a.badfda7a seq: 0xdf flg: 0xba
 spare1: 0xdf spare2: 0xba spare3: 0xbadf
 consistency value in tail: 0xbadfda7a
 check value in block header: 0xda7a
 block checksum disabled



DBVERIFY - Verification complete

Total Pages Examined         : 655360
Total Pages Processed (Data) : 549193
Total Pages Failing   (Data) : 0
Total Pages Processed (Index): 91832
Total Pages Failing   (Index): 0
Total Pages Processed (Other): 7163
Total Pages Processed (Seg)  : 0
Total Pages Failing   (Seg)  : 0
Total Pages Empty            : 7171
Total Pages Marked Corrupt   : 1   >>>>Corrupt
Total Pages Influx           : 0
Total Pages Encrypted        : 0
Highest block SCN            : 0 (0.0)

验证文件损坏

通过dbv检查发现数据文件确实存在坏块,进一步确认占用坏块的对象
backup validate datafile 681;

[oracle@xx02 ~]$ more /u01/app/oracle/diag/rdbms/xxxxdb/xxxxdb2/trace/xxxxdb2_ora_53650.trc 
Trace file /u01/app/oracle/diag/rdbms/xxxxdb/xxxxdb2/trace/xxxxdb2_ora_53650.trc
Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Production
With the Partitioning, Real Application Clusters, Automatic Storage Management, OLAP,
Data Mining and Real Application Testing options
ORACLE_HOME = /u01/app/oracle/product/11.2.0.4/dbhome_1
System name:	Linux
Node name:	xx02
Release:	2.6.39-400.250.4.el6uek.x86_64
Version:	#1 SMP Tue Jun 2 14:50:33 PDT 2015
Machine:	x86_64
Instance name: xxxxdb2
Redo thread mounted by this instance: 2
Oracle process number: 1109
Unix process pid: 53650, image: oracle@xx02 (TNS V1-V3)


*** 2021-11-22 09:55:29.441
*** SESSION ID:(3113.16425) 2021-11-22 09:55:29.441
*** CLIENT ID:() 2021-11-22 09:55:29.441
*** SERVICE NAME:(SYS$USERS) 2021-11-22 09:55:29.441
*** MODULE NAME:(backup full datafile) 2021-11-22 09:55:29.441
*** ACTION NAME:(0000015 STARTED19) 2021-11-22 09:55:29.441
 
Hex dump of (file 681, block 8212)
Dump of memory from 0x00007FBE6DF54000 to 0x00007FBE6DF56000
7FBE6DF54000 BADFDA7A BADFDA7A BADFDA7A BADFDA7A  [z...z...z...z...]
  Repeat 511 times
Corrupt block relative dba: 0xaa402014 **(file 681, block 8212)**  <<<< block 8212
Bad header found during validation
Data in bad block:
 type: 122 format: 2 rdba: 0xbadfda7a
 last change scn: 0xda7a.badfda7a seq: 0xdf flg: 0xba
 spare1: 0xdf spare2: 0xba spare3: 0xbadf
 consistency value in tail: 0xbadfda7a
 check value in block header: 0xda7a
 block checksum disabled
ksfdrfms:Mirror Read file=+DATAC1/xxxxdb/datafile/xx_tbs.3223.1044115207 fob=0x8b2909ad0 bufp=0x7fbe73460000 blkno=8212 nbytes=8192
ksfdrfms: Read success from mirror side=1 logical extent number=0 disk=DATAC1_CD_09_DM04CEL04 path=o/192.168.10.1;192.168.10.2/DATAC1_CD_dm1
Mirror I/O done from ASM disk o/192.168.10.1;192.168.10.2/DATAC1_CD_dm1
Trying mirror side DATAC1_CD_dm1.

通过SQL确认对象信息

SELECT e.owner,
e.segment_type,
e.segment_name,
e.partition_name,
c.file#,
greatest(e.block_id, c.block#) corr_start_block#,
least(e.block_id + e.blocks - 1, c.block# + c.blocks - 1) corr_end_block#,
least(e.block_id + e.blocks - 1, c.block# + c.blocks - 1) -
greatest(e.block_id, c.block#) + 1 blocks_corrupted,
null description
FROM dba_extents e, v$database_block_corruption c
WHERE e.file_id = c.file#
AND e.block_id <= c.block# + c.blocks - 1
AND e.block_id + e.blocks - 1 >= c.block#
UNION
SELECT s.owner,
s.segment_type,
s.segment_name,
s.partition_name,
c.file#,
header_block corr_start_block#,
header_block corr_end_block#,
1 blocks_corrupted,
'Segment Header' description
FROM dba_segments s, v$database_block_corruption c
WHERE s.header_file = c.file#
AND s.header_block between c.block# and c.block# + c.blocks - 1
UNION
SELECT null owner,
null segment_type,
null segment_name,
null partition_name,
c.file#,
greatest(f.block_id, c.block#) corr_start_block#,
least(f.block_id + f.blocks - 1, c.block# + c.blocks - 1) corr_end_block#,
least(f.block_id + f.blocks - 1, c.block# + c.blocks - 1) -
greatest(f.block_id, c.block#) + 1 blocks_corrupted,
'Free Block' description
FROM dba_free_space f, v$database_block_corruption c
WHERE f.file_id = c.file#
AND f.block_id <= c.block# + c.blocks - 1
AND f.block_id + f.blocks - 1 >= c.block#
order by file#, corr_start_block#;

确认坏块上的段

SQL> SELECT tablespace_name, segment_type, owner, segment_name
FROM dba_extents
WHERE file_id = &fileid
and &blockid between block_id AND block_id + blocks - 1;  2    3    4  
Enter value for fileid: 681
old   3: WHERE file_id = &fileid
new   3: WHERE file_id = 681
Enter value for blockid: 8212
old   4: and &blockid between block_id AND block_id + blocks - 1
new   4: and 8212 between block_id AND block_id + blocks - 1

TABLESPACE_NAME 	 SEGMENT_TYPE	  OWNER      SEGMENT_NAME
------------------ -------------  ---------- -------------------
xx_tbs		         TABLE		      XXX        xxx_GROUP_20200721

通过rman恢复

RUN {
ALLOCATE CHANNEL ch00 TYPE 'SBT_TAPE';
send 'NB_ORA_CLIENT=db01-10g';
blockrecover datafile 681 block 8212;
RELEASE CHANNEL ch00;
}

标签:blocks,Pages,Oracle,file,坏块,RMAN,Total,id,block
From: https://blog.51cto.com/u_13482808/8946158

相关文章

  • oracle 增量导入导出参考链接
    https://www.cnblogs.com/hsz1124/p/11648109.htmlhttps://blog.csdn.net/valkyrja110/article/details/121215821https://blog.csdn.net/csdnss1111/article/details/100321510https://blog.csdn.net/csdnss1111/article/details/100321510https://zhuanlan.zhihu.com/p/......
  • 2、oracle的while循环
    目录oracle的while循环1、语法2、使用oracle的while循环1、语法while[condition]loop[execute]endloop;2、使用v_count:=1;--当查询的条件数量为0时自动跳出while循环whilev_count>0loop selectcount(1)intov_countfromt_tabwheretask_status='0'; u......
  • oracle的一些记录
    1、恢复数据flashbacktableUF_DRZRYtotimestampto_timestamp('2022-06-2011:37:11','yyyy-mm-ddhh24:MI:SS');altertableUF_DRZRYenablerowmovement;2、删除的表select*fromuser_recyclebintwheret.original_name=upper('uf_person_kq_......
  • oracle 19c install steps
    oracle19cinstallsteps1.VMware-workstation-full-17.5.0downloadandsetup2.redhat8.9,vncdownloadandsetup--------------------------VNCConfigStepsVmware安装redhat8.9连接网络subscription-managerregister注册redhat账户vi/etc/selinux/config,设置S......
  • Oracle中给表赋予权限
    在Oracle数据库中,为表赋予权限的作用是允许或限制其他用户对该表进行特定操作的访问和修改。通过授权表权限,可以确保数据库的安全性和数据的保护。以下是一些常见的表权限以及它们的作用:SELECT:允许用户查询表中的数据。INSERT:允许用户向表中插入新的数据。UPDATE:允许用户修改表......
  • A. Anonymous Informant
    原题链接前言一道精简但是内容丰富的题一些事实1.循环左移len位后数组的节点对应原数组的节点,相当于在无限自复制循环的数组中将原来的节点右移len位2.如果该数组能被定点数组循环左移x位得到,那么该数组最后一个节点的值一定是x3.不管怎么位移,可能的数组最多只有n种不同的情......
  • Oracle12c新增max_idle_time参数的学习与感触
    Oracle12c新增max_idle_time参数的学习与感触TLDR其实任何软件出了新版本.readme是很重要的.尤其是数据库,涉及到底层问题的.比如这次遇到的Oracle的max_idle_time参数,以及前几天遇到的Mysql的新增的parallel关键字.自己之前的积累可能是一盏明灯,也可能是一堵墙.......
  • debezium同步Oracle数据时,更新操作只有被变更字段,其余字段值为null,主键ID值为0
    1.情景展示使用debezium的Oracle插件(io.debezium.connector.oracle.OracleConnector)自动读取Oracle的归档日志。当我对Oracle数据库受监控的表(待同步表),进行更新操作后,debezium会自动将变更记录推送到kafka当中。新增和删除操作,数据都能同步到另一个数据库。但是,更新操作,数据......
  • IPQ8074/IPQ8072 What's the performance difference?|8X8 4X4 High Performance 802.
    IPQ8074/IPQ8072What'stheperformancedifference?|8X84X4HighPerformance802.11axSolutionInthefast-pacedworldofwirelessconnectivity,choosingtherightroutermotherboardcanmakeallthedifferenceinyournetwork'sperformance.Inth......
  • 高等数值分析(高性能计算,并行计算) (Parallel and High Performance Computing)
    https://github.com/OpenMPhttps://math.ecnu.edu.cn/~jypan/Teaching/ParaComp/ParallelandHighPerformanceComputing(高等数值分析(高性能计算,并行计算))基本信息:教材:本课程主要讲授数值并行计算,内容以课堂讲义为主主要参考资料:并行计算与实现技术,迟学斌等,科学出版社,20......