Oracle Backup Trace File & AlertLog schedule on Everyday (shell script)

1. create script by Oracle or Grid

$ vim bkOraLog.sh

#!/usr/bin/ksh
#==========================================================================
#       USAGE : bkOraLog.sh
# DESCRIPTION : Backup oracle alert/listener/trace log everyday
#      AUTHOR : 
#     CREATED : 
#    REVISION : 1
#=========================================================================
source /home/oracle/.bash_profile

# set scripts ENV
HOSTNAME=`hostname`
ALERTDIR=/u01/app/oracle/diag/rdbms/${ORACLE_UNQNAME}/${ORACLE_SID}/trace
ALERTLOG="alert_"${ORACLE_SID}".log"
LISTENERDIR=/u01/app/grid/diag/tnslsnr/${HOSTNAME}/listener/trace
LISTENERLOG="listener.log"
LISTENERLOGS="listener_*.log"
LISTENERDIRX=/u01/app/grid/diag/tnslsnr/${HOSTNAME}/listener/alert
LISTENERLOGX="log_*.xml"
ADUMPDIR=/u01/app/oracle/admin/${ORACLE_UNQNAME}/adump
BKDIR=/logbk/${HOSTNAME}
TODAY=`date -d "-1 days" +%Y%m%d`
SUORAC="su - oracle -c "
SUGRID="su - grid -c "
SCRIPTNAME=`basename "$0"`

if [ ! -d ${BKDIR} ]; then
  echo "mkdir -p ${BKDIR}"
  ${SUORAC} "mkdir -p ${BKDIR}"
fi

# remove old file
find ${BKDIR} -type f -mtime +90 -exec rm -f {} \;

# remove old adump file
find ${ADUMPDIR} -type f -mtime +90 -exec rm -f {} \;

# backup alert log
${SUORAC} "cp -p ${ALERTDIR}/${ALERTLOG} ${BKDIR}/${ALERTLOG}.${TODAY}"
if [ $? -eq 0 ]
then
  echo "cat /dev/null > ${ALERTDIR}/${ALERTLOG}"
  ${SUORAC} "cat /dev/null > ${ALERTDIR}/${ALERTLOG}"
else
  echo `date` >> /tmp/${SCRIPTNAME}.log
  echo "Error!!! cp -p ${ALERTDIR}/${ALERTLOG} ${BKDIR}/${ALERTLOG}.${TODAY}" >> /tmp/${SCRIPTNAME}.log
fi

# backup listener log
${SUORAC} "cp -p ${LISTENERDIR}/${LISTENERLOG} ${BKDIR}/${LISTENERLOG}.${TODAY}"
if [ $? -eq 0 ]
then
  echo "cat /dev/null > ${LISTENERDIR}/${LISTENERLOG}"
  ${SUGRID} "cat /dev/null > ${LISTENERDIR}/${LISTENERLOG}"

  # move mutiple listener_*.log
  for f in ${LISTENERDIR}/${LISTENERLOGS}
  do
      ${SUORAC} "cp ${f} ${BKDIR}/$(basename $f).${TODAY}"
      ${SUGRID} "rm -f ${f}"
  done

  # remove listener xml
  find ${LISTENERDIRX}/${LISTENERLOGX} -type f -mtime +7 -exec rm -f {} \;
else
  echo `date` >> /tmp/${SCRIPTNAME}.log
  echo "Error!!! cp -p ${LISTENERDIR}/${LISTENERLOG} ${BKDIR}/${LISTENERLOG}.${TODAY}" >> /tmp/${SCRIPTNAME}.log
fi

# Backup Trace File
cd ${ALERTDIR}
${SUORAC} "cd ${ALERTDIR} && tar --warning=no-file-changed -zcvf ${BKDIR}/TRACE.${TODAY}.tar.gz *.trc *.trm > ${BKDIR}/TRACE.${TODAY}.tar.log"
if [ $? -eq 0 ] || [ $? -eq 1 ]
then
  echo "rm -f ${ALERTDIR}/*.trc"
  echo "rm -f ${ALERTDIR}/*.trm"
  rm -f ${ALERTDIR}/*.trc
  rm -f ${ALERTDIR}/*.trm
else
  echo `date` >> /tmp/${SCRIPTNAME}.log
  echo "Error!!! tar --warning=no-file-changed -zcvf ${BKDIR}/TRACE.${TODAY}.tar.gz *.trc *.trm" >> /tmp/${SCRIPTNAME}.log
fi

# Purge old content than 7 days using by adrci
${SUORA} "adrci exec=\"show homes\"|grep -v :"| while read file_line
do
${SUORA} "adrci exec=\"set homepath $file_line;purge -age 10080 -type ALERT\""
${SUORA} "adrci exec=\"set homepath $file_line;purge -age 10080 -type INCIDENT\""
${SUORA} "adrci exec=\"set homepath $file_line;purge -age 10080 -type TRACE\""
${SUORA} "adrci exec=\"set homepath $file_line;purge -age 10080 -type CDUMP\""
${SUORA} "adrci exec=\"set homepath $file_line;purge -age 10080 -type UTSCDMP\""
${SUORA} "adrci exec=\"set homepath $file_line;purge -age 10080 -type HM\""
${SUORA} "adrci exec=\"set homepath $file_line;purge -age 10080 -type LOG\""
done

# Remove Cluster Old File
for adrhome in `${SUGRID} "adrci exec=""show home"""`;
do
  if [[ ( "${adrhome}" != "ADR" ) && ( "${adrhome}" != "Homes:" ) ]]
  then
    # Change to 7 Days
    ${SUGRID} "adrci exec='""SET HOME $adrhome; set control \(LONGP_POLICY = 2160\); set control \(SHORTP_POLICY = 2160\)""'"
    # Delete Old Thand 7 Days
    ${SUGRID} "adrci exec='""SET HOME $adrhome; purge -age 10080;""'"
  fi;
done;


2. edit crontab by root ( the script will be change user )

# crontab -e
0 0 * * * {SCIRPT_PATH}/bkOraLog.sh > /dev/null 2>&1

張貼留言

0 留言