Linux/Unix shell 监控Oracle告警日志(monitor alter log file)
使用shell脚本实现对Oracle数据库的监控与管理将大大简化DBA的工作负担,如常见的对实例的监控,监听的监控,告警日志的监控,以及数据库的备份,AWR report的自动邮件等。本文给出Linux 下使用 shell 脚本来监控 Oracle 告警日志(monitor alter log file)。
Linux Shell的相关参考:
Linux/Unix shell 脚本中调用SQL,RMAN脚本 Linux/Unix shell sql 之间传递变量 Linux/Unix shell 调用 PL/SQL Linux/Unix shell 监控Oracle实例(monitor instance)
Linux/Unix shell 监控Oracle监听器(monitor listener)
1、监控Oracle告警日志脚本
- robin@SZDB:~/dba_scripts/custom/bin> more ck_alert.sh
- #!/bin/bash
- # --------------------------------------------------------------------------+
- # CHECK ALERT LOG FILE |
- # Filename: ck_alert.sh |
- # Desc: |
- # The script use to check alert log file. |
- # Once any error was caught, a mail alert will be sent. |
- # Deploy it by crontab. e.g. per 15 min |
- # Usage: |
- # ./ck_alert.sh $ORACLE_SID |
- # |
- # Author : Robinson |
- # Blog : http://blog.csdn.net/robinson_0612 |
- # --------------------------------------------------------------------------+
- #
- # --------------------------
- # Check SID
- # --------------------------
- if [ -z "${1}" ];then
- echo "Usage: "
- echo " `basename $0` ORACLE_SID"
- exit 1
- fi
- # -------------------------------
- # Set environment here
- # ------------------------------
- if [ -f ~/.bash_profile ]; then
- . ~/.bash_profile
- fi
- export ORACLE_SID=$1
- export MACHINE=`hostname`
- export MAIL_DIR=/users/robin/dba_scripts/sendEmail-v1.56
- export MAIL_LIST='Robinson.cheng@12306.com'
- export MAIL_FM='oracle@szdb.com'
- # ----------------------------------------------
- # check the database is running, if not exit
- # ----------------------------------------------
- db_stat=`ps -ef | grep pmon_$ORACLE_SID | grep -v grep| cut -f3 -d_`
- if [ -z "$db_stat" ]; then
- date >/tmp/db_${ORACLE_SID}_stauts.log
- echo " $ORACLE_SID is not available on ${MACHINE} !!!" >>/tmp/db_${ORACLE_SID}_stauts.log
- MAIL_SUB=" $ORACLE_SID is not available on ${MACHINE} !!!"
- $MAIL_DIR/sendEmail -u $MAIL_SUB -f $MAIL_FM -t $MAIL_LIST -o message-file=/tmp/db_${ORACLE_SID}_stauts.log
- exit 1
- fi;
- # --------------------------------------
- # Get the location of alert log file
- # --------------------------------------
- sqlplus '/ as sysdba' << EOF > /tmp/${ORACLE_SID}_monitor_temp.txt
- column xxxx format a10
- column value format a80
- set lines 132
- SELECT 'xxxx' ,value FROM v\$parameter WHERE name = 'background_dump_dest'
- /
- exit
- EOF
- cat /tmp/${ORACLE_SID}_monitor_temp.txt | awk '$1 ~ /xxxx/ {print $2}' > /tmp/${ORACLE_SID}_monitor_location.txt
- read ALERT_DIR < /tmp/${ORACLE_SID}_monitor_location.txt
- rm /tmp/${ORACLE_SID}_monitor_temp.txt 2>/dev/null
- # ----------------------------------------
- # Define archive directory and log file
- # ----------------------------------------
- DT=`date +%Y%m%d`
- DT_DIR=`date +%Y%m`
- ARCH_DIR=${ALERT_DIR}/${DT_DIR}
- if [ ! -d "${ARCH_DIR}" ] ; then
- mkdir $ARCH_DIR
- fi
- ORIG_ALERT_LOG=${ALERT_DIR}/alert_${ORACLE_SID}.log
- NEW_ALERT_LOG=${ARCH_DIR}/alert_${ORACLE_SID}.log.${DT}
- TEMP_ALERT_LOG=${ORIG_ALERT_LOG}.temp
- AWK_DIR=/users/robin/dba_scripts/custom/bin
- # -------------------------------------
- # Check alert log file and send email
- # -------------------------------------
- cat ${ORIG_ALERT_LOG} | awk -f $AWK_DIR/check_alert.awk > /tmp/${ORACLE_SID}_check_monitor_log.log
- if [ -s "/tmp/${ORACLE_SID}_check_monitor_log.log" ];
- then
- echo "Found errors in sid ${ORACLE_SID}, mailed errors"
- echo -e "The following errors were found in the alert log for ${ORACLE_SID} \n" > /tmp/${ORACLE_SID}_check_monitor_log.mail
- echo -e "Alert log was copied into ${NEW_ALERT_LOG} \n">> /tmp/${ORACLE_SID}_check_monitor_log.mail
- date >> /tmp/${ORACLE_SID}_check_monitor_log.mail
- echo "--------------------------------------------------------------">>/tmp/${ORACLE_SID}_check_monitor_log.mail
- echo " "
- echo " " >> /tmp/${ORACLE_SID}_check_monitor_log.mail
- echo " " >> /tmp/${ORACLE_SID}_check_monitor_log.mail
- cat /tmp/${ORACLE_SID}_check_monitor_log.log >> /tmp/${ORACLE_SID}_check_monitor_log.mail
- MAIL_SUB="Found errors in ${ORACLE_SID} on ${MACHINE}"
- $MAIL_DIR/sendEmail -u $MAIL_SUB -f $MAIL_FM -t $MAIL_LIST -o message-file=/tmp/${ORACLE_SID}_check_monitor_log.mail
- # --------------------------------
- # Backup current alert log file
- # --------------------------------
- mv ${ORIG_ALERT_LOG} ${TEMP_ALERT_LOG}
- cat ${TEMP_ALERT_LOG} >> ${NEW_ALERT_LOG}
- #touch ${ORIG_ALERT_LOG}
- cat /dev/null > ${ORIG_ALERT_LOG}
- rm /tmp/${ORACLE_SID}_check_monitor_log.log
- rm /tmp/${ORACLE_SID}_check_monitor_log.mail
- rm ${TEMP_ALERT_LOG} > /dev/null
- exit
- fi
- rm /tmp/${ORACLE_SID}_check_monitor_log.log > /dev/null
- rm /tmp/${ORACLE_SID}_monitor_location.txt > /dev/null
- exit
2、过滤Oracle告警日志错误信息
- robin@SZDB:~/dba_scripts/custom/bin> more check_alert.awk
- $0 ~ /Errors in file/ {print $0}
- $0 ~ /PMON: terminating instance due to error 600/ {print $0}
- $0 ~ /Started recovery/{print $0}
- $0 ~ /Archival required/{print $0}
- $0 ~ /Instance terminated/ {print $0}
- $0 ~ /Checkpoint not complete/ {print $0}
- $1 ~ /ORA-/ { print $0; flag=1 }
- $0 !~ /ORA-/ {if (flag==1){print $0; flag=0;print " "} }
- $0 ~ /ERROR_AUDIT/ {print $0}
3、老化Oracle告警日志脚本
- robin@SZDB:~/dba_scripts/custom/bin> more age_alert.sh
- #!/bin/bash
- # ------------------------------------------------------------+
- # Age the alert log file |
- # FileName: age_alert.sh |
- # Desc: |
- # The script use to age the alert log file |
- # Usage: |
- # ./age_alert.sh $ORACLE_SID |
- # |
- # Authror : Robinson |
- # Blog : http://blog.csdn.net/robinson_0612 |
- # ------------------------------------------------------------+
- # --------------------------
- # Check SID
- # --------------------------
- if [ -z "${1}" ];then
- echo "Usage: "
- echo " `basename $0` ORACLE_SID"
- exit 1
- fi
- # -------------------------------
- # Set environment here
- # ------------------------------
- if [ -f ~/.bash_profile ]; then
- . ~/.bash_profile
- fi
- export MAIL_DIR=/users/robin/dba_scripts/sendEmail-v1.56
- export MAIL_LIST='Robinson.cheng@12306.com'
- export MAIL_FM='oracle@szdb.com'
- ORACLE_SID=$1; export ORACLE_SID
- # ----------------------------------------------
- # check if the database is running, if not exit
- # ----------------------------------------------
- db_stat=`ps -ef | grep pmon_$ORACLE_SID | grep -v grep| cut -f3 -d_`
- if [ -z "$db_stat" ]; then
- echo " $ORACLE_SID is not available on `hostname` !!!"
- MAIL_SUB=" $ORACLE_SID is not available on `hostname` !!!"
- MAIL_MSG="$ORACLE_SID is not available on `hostname` before age alert log file, exit, please check !"
- $MAIL_DIR/sendEmail -u $MAIL_SUB -f $MAIL_FM -t $MAIL_LIST -m $MAIL_MSG
- exit 1
- fi
- # -----------------------------------
- # Find bdump directory for database
- # -----------------------------------
- DUMP_DIR=`sqlplus -S '/ as sysdba' << EOF
- set pagesize 0 feedback off verify off heading off echo off
- SELECT value FROM v\\$parameter WHERE name = 'background_dump_dest';
- exit
- EOF`
- if [ -z ${DUMP_DIR} ]; then
- echo "The bdump directory was not found for ${ORACLE_SID}"
- MAIL_SUB="The bdump directory was not found for ${ORACLE_SID}"
- MAIL_MSG="The bdump directory was not found for ${ORACLE_SID} on `hostname` before age log file,exit,please check !"
- $MAIL_DIR/sendEmail -u $MAIL_SUB -f $MAIL_FM -t $MAIL_LIST -m $MAIL_MSG
- exit 1
- else
- echo ${DUMP_DIR}
- fi
- # -------------------------------
- # Archive alert log file
- # -------------------------------
- DT=`date +%Y%m%d -d '-1 day'`
- OLD_DIR=${DT:0:6}
- NEW_DIR=`date +%Y%m`
- ORIG_ALERT_LOG=${DUMP_DIR}/alert_${ORACLE_SID}.log
- OLD_ARC_DIR=${DUMP_DIR}/${OLD_DIR}
- NEW_ARC_DIR=${DUMP_DIR}/${NEW_DIR}
- if [ ! -d "${NEW_ARC_DIR}" ] ; then
- mkdir ${NEW_ARC_DIR}
- fi
- if [ "${OLD_DIR}" \< "${NEW_DIR}" ];then
- ARC_LOG=${OLD_ARC_DIR}/alert_${ORACLE_SID}.log.${DT}
- else
- ARC_LOG=${NEW_ARC_DIR}/alert_${ORACLE_SID}.log.${DT}
- fi
- cat ${ORIG_ALERT_LOG} >>${ARC_LOG}
- cat /dev/null>${ORIG_ALERT_LOG}
- exit
4、部署脚本到crontab
- */15 * * * * /users/robin/dba_scripts/custom/bin/ck_alert.sh MMBOTST
- 0 0 * * * /users/robin/dba_scripts/custom/bin/age_alert.sh MMBOTST
5、补充
a、上面脚本用于实时监控Oracle告警日志,一旦检测到错误,将发送邮件。
b、对于已经检查过且发现错误的日志将被移动作为归档,也就是Oracle错误不会被重复检测。
c、所有有关错误检测的过滤条件被放置到过滤文件check_alert.awk中。
d、第3个脚本用于老化告警日志,建议设置老化的时间为每天0点,这样子,每天将会保留当天的告警日志。
e、对于老化的告警日值,按年月来存放,也即是以年月命名文件夹,当天告警日志会存放在当月文件夹。
f、使用了sendEmail邮件发送程序来发送邮件。参阅:不可或缺的 sendEmail g、该脚本仅在Oracle 10g测试可用,Oracle 11g应做相应修改。
转:http://blog.csdn.net/leshami/article/details/8569759
Linux/Unix shell 监控Oracle告警日志(monitor alter log file)的更多相关文章
- Linux/Unix shell 监控Oracle监听器(monitor listener)
使用shell脚本实现对Oracle数据库的监控与管理将大大简化DBA的工作负担,如常见的对实例的监控,监听的监控,告警日志的监控,以及数据库的备份,AWR report的自动邮件等.本文给出Linu ...
- Linux/Unix shell 监控Oracle实例(monitor instance)
使用shell脚本实现对Oracle数据库的监控与管理将大大简化DBA的工作负担,如常见的对实例的监控,监听的监控,告警日志的监控,以及数据库的备份,AWR report的自动邮件等.本文给出Linu ...
- Linux/Unix shell 脚本中调用SQL,RMAN脚本
Linux/Unix shell脚本中调用或执行SQL,RMAN 等为自动化作业以及多次反复执行提供了极大的便利,因此通过Linux/Unix shell来完成Oracle的相关工作,也是DBA必不可 ...
- Linux/Unix shell sql 之间传递变量
灵活结合Linux/Unix Shell 与SQL 之间的变量传输,极大程度的提高了DBA的工作效率,本文针对Linux/Unix shell sql 之间传递变量给出几个简单的示例以供参考. Lin ...
- Linux/Unix shell 自动发送AWR report(二)
观察Oracle数据库性能,Oracle自带的awr 功能为我们提供了一个近乎完美的解决方案,通过awr特性我们可以随时从数据库提取awr报告.不过awrrpt.sql脚本执行时需要我们提供一些交互信 ...
- Oracle 联机重做日志文件(ONLINE LOG FILE)
--========================================= -- Oracle 联机重做日志文件(ONLINE LOG FILE) --================== ...
- ORACLE告警日志文件
告警日志介绍 告警日志文件是一类特殊的跟踪文件(trace file).告警日志文件命名一般为alert_<SID>.log,其中SID为ORACLE数据库实例名称.数据库告警日志是按时间 ...
- ORACLE告警日志
告警日志介绍 告警日志文件是一类特殊的跟踪文件(trace file).告警日志文件命名一般为alert_<SID>.log,其中SID为ORACLE数据库实例名称.数据库告警日志是按时间 ...
- Linux/Unix shell 自动发送AWR report
观察Oracle数据库性能,Oracle自带的awr 功能为我们提供了一个近乎完美的解决方案,通过awr特性我们可以随时从数据库提取awr报告.不过awrrpt.sql脚本执行时需要我们提供一些交互信 ...
随机推荐
- CentOS系统配置redis
1.切换到/usr/sr cd /usr/src wget http://download.redis.io/releases/redis-3.2.0.tar.gz 2.解压,安装 tar x ...
- iOS开发--应用程序上线
iOS应用上线 http://www.jianshu.com/p/ffddc5e5f0b9 iOS真机测试 http://www.jianshu.com/p/986e02d38f1b iOS应用程序打 ...
- SPRING IN ACTION 第4版笔记-第十一章Persisting data with object-relational mapping-003编写JPA-based repository( @PersistenceUnit、 @PersistenceContext、PersistenceAnnotationBeanPostProcessor)
一.注入EntityManagerFactory的方式 package com.habuma.spittr.persistence; import java.util.List; import jav ...
- CSS3:empty
:empty ---空的元素样式 <!DOCTYPE html> <html> <head lang="en"> <meta charse ...
- Oracle ->> 随机函数
SQL SERVER下生成随机数据干得多,可是到了Oracle下我就傻了.没用过Oracle,不知道该怎么办?SQL SERVER下依靠TABLESAMPLE或者CHECKSUM(NEWID())来做 ...
- javascript Klass 实现
var Klass=function(Parent,props){ var Child,F,i; Child=function(){ if(Child.uber && Child.ub ...
- C#基础(二)
变量的命名规则: 1.变量名由字母,数字 ,下划线组成.@ 中文 2.首字母,不能是数字 3.不能与关键字重名 变量的定义 语法: 数据类型 变量名[=值]; int a; //只定义变量 ...
- 由阿里巴巴笔试题看java加载顺序
一.阿里巴巴笔试题: public class T implements Cloneable { public static int k = 0; public static T t1 = new T ...
- zabbix接口调用注意事项--Python
不知道该怎么写,但是明显得写点什么,担心时间长了,忘记,再回顾时又要重新摸索一遍 一.Request:post params: 1. 第一层的参数处理: 第一层的参数设置为变量 2. 其他层参数格式不 ...
- C# winFrom 制作、打包、签名、发布Activex全过程
注:转自园中 http://www.cnblogs.com/still-windows7/p/3148623.html 一.前言 最近有这样一个需求,需要在网页上面启动客户端的软件,软件之间的通信.调 ...