RMAN-08137: warning: archived log not deleted, needed for standby or upstream capture process

Ingeniero informático, Oracle ACE, DBA y Arquitecto OCI, con más de 15 años de experiencia en plataformas Oracle. Certificado en OCI Certified Architect Professional y OCI Migration and Integration Certified Professional.
A la hora de revisar porque RMAN no era capaz de eliminar los archive logs dándonos el siguiente error:
RMAN-08137: warning: archived log not deleted, needed for standby or upstream capture process
archived log file name=+RECO/XXXXXX/ARCHIVELOG/2024_07_26/thread_2_seq_31382.5872.1175352221 thread=2 sequence=31382
RMAN-08137: warning: archived log not deleted, needed for standby or upstream capture process
archived log file name=+RECO/XXXXXX/ARCHIVELOG/2024_07_26/thread_2_seq_31383.3853.1175352377 thread=2 sequence=31383
Este error es causado porque en una migración no eliminaron de manera correcta los procesados integrados del extract de un ogg.
SQL> r
1 Select Capture_Name,
2 Capture_Type,
3 Status,
4 To_Char(Required_Checkpoint_Scn, '999999999999999') As Req_Scn,
5 To_Char(Oldest_Scn, '999999999999999') As Oldest_Scn
6* From Dba_Capture
CAPTURE_NAME CAPTURE_TY STATUS REQ_SCN OLDEST_SCN
------------------ ---------- -------- ---------------- ----------------
OGG$CAP_KA2 LOCAL DISABLED 0 0
OGG$CAP_KA2 LOCAL DISABLED 0 0
Para eliminarlo, deberíamos entrar en el ogg y ejecutar la siguiente sentencia para cada proceso que se ha quedado obsoleto UNREGISTER EXTRACT #CAPTURE_NAME# DATABASE.
Una vez lanzada la sentencia anterior, si consultamos de nuevo la consulta debería devolvernos cero filas en caso que lo hayamos realizado bien
SQL> r
1 Select Capture_Name,
2 Capture_Type,
3 Status,
4 To_Char(Required_Checkpoint_Scn, '999999999999999') As Req_Scn,
5 To_Char(Oldest_Scn, '999999999999999') As Oldest_Scn
6* From Dba_Capture
no rows selected
Ejecutamos nuestro pequeño scripts para comprobar que podemos ya eliminar esos archive logs obsoletos
[oracle@_scripts]$ cat rman.sh
#!/bin/bash
. /home/oracle/.bashrc
LOG=$(hostname -s)_`date +%Y%m%d%H%M%S`
touch ${P_RAIZ}/log/${LOG}.log
rman target / log=${P_RAIZ}/log/${LOG}.log << EOF
run
{
DELETE NOPROMPT ARCHIVELOG ALL COMPLETED BEFORE 'SYSDATE-1';
}
EOF
[oracle@_scripts]$ . rman.sh
[oracle@_scripts]$
Listo. ¡Espero que os sirva!
![[26ai] Limpieza de objetos obsoletos en desuso](/_next/image?url=https%3A%2F%2Fcdn.hashnode.com%2Fuploads%2Fcovers%2F65605419d28f19cc44df7ef1%2F93181086-1008-4184-8454-33b7367ebedb.png&w=3840&q=75)
![[26ai] Hybrid Read-Only Mode PDB](/_next/image?url=https%3A%2F%2Fcdn.hashnode.com%2Fuploads%2Fcovers%2F65605419d28f19cc44df7ef1%2Fde208bd2-5e24-4fd3-acf7-8e5394d95283.png&w=3840&q=75)
![[26ai] ALERT_LOG_MAX_SIZE](/_next/image?url=https%3A%2F%2Fcdn.hashnode.com%2Fuploads%2Fcovers%2F65605419d28f19cc44df7ef1%2Fcbb365d0-4428-4a41-930d-516ce59e3355.jpg&w=3840&q=75)
![[26ai] ConnStr Tool](/_next/image?url=https%3A%2F%2Fcdn.hashnode.com%2Fuploads%2Fcovers%2F65605419d28f19cc44df7ef1%2F5005f06e-946c-49ba-bfe8-7fe18d1075d9.png&w=3840&q=75)
![[26ai] Instalación de Oracle26ai en Linux 9](/_next/image?url=https%3A%2F%2Fcdn.hashnode.com%2Fuploads%2Fcovers%2F65605419d28f19cc44df7ef1%2Fd9a6ba10-eb2d-4fee-8a0c-f4957cbdc676.png&w=3840&q=75)