[OCI] housekeeping /u01
![[OCI] housekeeping /u01](/_next/image?url=https%3A%2F%2Fcdn.hashnode.com%2Fres%2Fhashnode%2Fimage%2Fupload%2Fv1732528944736%2Fc0698004-54ee-4d14-903f-ceccbfd84ffc.jpeg&w=3840&q=75)
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.
Os comparto un script sencillo para tener controlado /u01, lo bueno del script es que cuando entra a realizar tareas de limpieza en /u01, nos mandara la siguiente alerta al correo, con el tamaño anterior y actual de realizar la limpieza

Este sería el código del script
#!/bin/bash
# DSM NTTDATA-DBA
. /home/oracle/.bashrc
NAME=`df -h | grep u01 | awk '{print $6}'`
USE=`df -h | grep u01 | awk '{print $5}' | sed -r 's/%//g'`
ADRCI_LOG="adrci_"`date +%Y%m%d%H%M%S`".log"
TODAY=$(date '+%Y-%m-%d %H:%M:%S')
# 5 sera el numero de dias que queremos mantener a nivel de trace
PURGE=$(expr 5 \* 24 \* 60)
if [[ ${USE} -gt 80 ]]
then
lanza_sqlplus() {
sqlplus -s ${VUSER}/${VPASS}@${LOCAL_SID} <<EOF
set lines 200 pages 9000
set termout off
set heading off
${SQL}
EXIT;
EOF
}
SQL=$(cat <<EOF
Select Value||chr(47) From V\$diag_Info Where Name='ADR Base'
;
EOF
)
set __ $(lanza_sqlplus)
ADRCI_BASE=${2}
SQL=$(cat <<EOF
Select Replace( Value, (Select Value || Chr(47) From V\$diag_Info Where Name='ADR Base'),'') Value
From V\$diag_Info Where Name='ADR Home'
;
EOF
)
set __ $(lanza_sqlplus)
ADRCI_HOME=${2}
echo "Base " ${ADRCI_BASE} " home " ${ADRCI_HOME}
adrci exec="set echo ON; spool ${P_RAIZ}/log/${ADRCI_LOG} append; set base ${ADRCI_BASE}; set homepath ${ADRCI_HOME}; purge -age ${PURGE}" >> ${P_RAIZ}/log/${ADRCI_LOG}
USE_ACTUAL=`df -h | grep u01 | awk '{print $5}' | sed -r 's/%//g'`
printf "Mantenimient ${NAME}\nSize Ant=${USE}\nAct=${USE_ACTUAL}" | mailx -s "[XXXX][XXXX] Mantenimiento ${NAME} with more ${USE} - ${TODAY}." ${EMAIL}
fi
Para que sea más fácil la descarga, lo he dejado subido en github.
Ahora solo faltaría planificarlo en cron. En mi caso lo dejo definido para que se ejecute cada hora.
[oracle@ scripts]# crontab -l
0 * * * * /home/oracle/scripts/check_u01.sh
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)