Uno de los problemas a los que tenemos que enfrentarnos dia a dia es el de lidiar con bloques corruptos en la base de datos.
Vayamos al supuesto en el que alguna de nuestras herramientas (RMNA,EMC,dbvf, el propio motor en algun acceso) ha detectado que tenemos estos bloques corruptos. La manera de encontarlos es mediante la vista V$DATABASE_BLOCK_CORRUPTION
SQL> select * from V$DATABASE_BLOCK_CORRUPTION; FILE# BLOCK# BLOCKS CORRUPTION_CHANGE# CORRUPTIO ---------- ---------- ---------- ------------------ --------- 2 88231 1 6821577 NOLOGGING 2 58442 1 6821577 NOLOGGING
Recuperacion de bloques corruptos
La manera de recuperarlos es tan sencillo como decirle al RMAN que lo haga, para esto ejecutaremos el comando de rman RECOVER CORRUPTION LIST;:RMAN> RECOVER CORRUPTION LIST; Starting recover at 14-JAN-18 using target database control file instead of recovery catalog allocated channel: ORA_DISK_1 channel ORA_DISK_1: SID=206 device type=DISK starting media recovery media recovery complete, elapsed time: 00:00:01 Finished recover at 14-JAN-18
Comprobacion de que han sido recuperados
Aunque rman nos haya dicho OK, deberemos revisar que los bloques estan correctos, para ello usaremos la opcion VALIDATE DATAFILE de RMAN aplicado al FILE# que nos indicaba la vista de bloques corruptosRMAN> validate datafile 2; Starting validate at 14-JAN-18 using channel ORA_DISK_1 channel ORA_DISK_1: specifying datafile(s) for validation input datafile file number=2 name=/u01/app/oracle/ORASID/sysaux01.dbf channel ORA_DISK_1: validation complete, elapsed time: 00:00:01 List of Datafiles ================= File Status Marked Corrupt Empty Blocks Blocks Examined High SCN ---- ------ -------------- ------------ --------------- ---------- 2 OK 0 21603 336384 41455048 Finished validate at 14-JAN-18
Y si no lo ha solucionado?
Que ocurre si RMAN no ha podido recuperar el bloque corrupto?
En este caso el comando validate nos devolveria algo similar a
RMAN> validate datafile 2; Starting validate at 14-JAN-18 using channel ORA_DISK_1 channel ORA_DISK_1: starting validation of datafile channel ORA_DISK_1: specifying datafile(s) for validation input datafile file number=2 name=/u01/app/oracle/ORASID/sysaux01.dbf channel ORA_DISK_1: validation complete, elapsed time: 00:00:01 List of Datafiles ================= File Status Marked Corrupt Empty Blocks Blocks Examined High SCN ---- ------ -------------- ------------ --------------- ---------- 2 OK 2 20225 99863 49937565 File Name: /u01/app/oracle/ORASID/sysaux01.dbf Block Type Blocks Failing Blocks Processed ---------- -------------- ---------------- Data 0 26483 Index 0 24051 Other 0 29081 Finished validate at 14-JAN-18
Por que puede ser esto?
En el caso en que no resolvamos el problema, echaremos un vistazo al alert.log,
ORA-01578: ORACLE data block corrupted (file # ORA-01578: ORACLE data block corrupted (file # 2, block # 58442) ORA-01110: data file 2: '/u01/app/oracle/ORASID/sysaux01.dbf' ORA-26040: Data block was loaded using the NOLOGGING option
Lo que nos esta indicando este error es que el objeto se creo en modo nologging por lo que la base de datos no tiene informacion de como recuperarla, si queremos recuperar esta informacion deberemos de recrear el objeto ( y cruzar los dedos para que este objeto sea un indice y no datos de negocio)
COmo siempre podemos encontrar mas informacion al respecto en soporte Oracle en las notas:
- How to identify the corrupt Object reported by ORA-1578 / RMAN / DBVERIFY (Doc ID 819533.1)
- ORA-1578 / ORA-26040 Corrupt blocks by NOLOGGING - Error explanation and solution (Doc ID 794505.1)
- How to identify all the Corrupted Objects in the Database with RMAN (Doc ID 472231.1)