使用shell脚本实现对Oracle数据库的监控与管理将大大简化DBA的工作负担,如常见的对实例的监控,监听的监控,告警日志的监控,以及数据库的备份,AWR report的自动邮件等。本文给出Linux 下使用 shell 脚本来监控 Oracle 实例。

Linux Shell的相关参考:
        Linux/Unix shell 脚本中调用SQL,RMAN脚本        Linux/Unix shell sql 之间传递变量        Linux/Unix shell 调用 PL/SQL

1、监控Oracle实例shell脚本

  1. robin@SZDB:~/dba_scripts/custom/bin> more ck_inst.sh
  2. # +-------------------------------------------------------+
  3. # +    CHECK INSTANCE STATUS AND SEND MAIL                |
  4. # +    Author : Robinson                                  |
  5. # +    Blog   : http://blog.csdn.net/robinson_0612        |
  6. # +    Desc:                                              |
  7. # +         variable X_DB use to exclude some instance    |
  8. # +-------------------------------------------------------+
  9. #!/bin/bash
  10. # --------------------------------------------
  11. # Set environment vairable and define variable
  12. # --------------------------------------------
  13. if [ -f ~/.bash_profile ]; then
  14. . ~/.bash_profile
  15. fi
  16. ORATAB=/etc/oratab
  17. TIMESTAMP=`date +%Y%m%d%H%M`
  18. MAILPATH=/users/robin/dba_scripts/sendEmail-v1.56
  19. LOG_DIR=/users/robin/dba_scripts/custom/log
  20. LOG_FILE=${LOG_DIR}/ck_inst_$TIMESTAMP.log
  21. DBALIST="robinson.cheng@12306.com;robinson_0612@12306.com"
  22. X_DB='SYBO2SZ|CNQDII|CNFO'
  23. RETENTION=1
  24. # ----------------------
  25. # Check instance status
  26. # ----------------------
  27. if [ -z "$X_DB" ]; then
  28. X_DB='DUMMY'
  29. fi
  30. {
  31. echo "`date` "
  32. echo "Oracle Database(s) Status on `hostname`"
  33. echo "-----------------------------------------"
  34. db=`egrep -i ":Y|:N" $ORATAB | cut -d":" -f1 | grep -v "\#" | grep -v "\*"`
  35. pslist=`ps -ef | grep pmon | grep -v grep`
  36. dblist=`for i in $db; do echo $i; done | grep -vP $X_DB`
  37. for i in $dblist; do
  38. echo "$pslist" | grep "[oa]*_pmon_$i" > /dev/null 2>&1
  39. if (( $? )); then
  40. echo "Oracle Instance - $i: Down"
  41. else
  42. echo "Oracle Instance - $i: Up"
  43. fi
  44. done;
  45. }|tee -a ${LOG_FILE} 2>&1
  46. # ------------------------
  47. # Send Email
  48. # ------------------------
  49. cnt=`cat $LOG_FILE | grep Down | wc -l`
  50. if [ "$cnt" -gt 0 ]; then
  51. $MAILPATH/sendEmail -f szdb@2gotrade.com -t $DBALIST -u "Instance status on `hostname`" -o message-file=$LOG_FILE
  52. fi
  53. # ------------------------------------------------
  54. # Removing files older than $RETENTION parameter
  55. # ------------------------------------------------
  56. find ${LOG_DIR} -name "ck_inst*.*" -mtime +$RETENTION -exec rm {} \;
  57. exit
  58. robin@SZDB:~/dba_scripts/custom/bin> ./ck_inst.sh
  59. Fri Feb  1 15:10:41 CST 2013
  60. Oracle Database(s) Status on SZDB
  61. -----------------------------------------
  62. Oracle Instance - CNBO1: Up
  63. Oracle Instance - CNBOTST: Down
  64. Oracle Instance - CNMMBO: Up
  65. Oracle Instance - MMBOTST: Up
  66. Oracle Instance - CNMMBOBK: Down
  67. Oracle Instance - CI8960U: Up
  68. Oracle Instance - CNBO2: Up
  69. Feb 01 15:10:41 szdb sendEmail[16024]: Email was sent successfully!

2、补充
  a、上面的脚本根据/etc/oratab中列出的实例进行监控,可以监控多个实例。
  b、变量X_DB用于排除那些不需要监控的实例,如脚本中排出了3个实例。也可以将该变量置空。
  c、如果X_DB的值为空时,我们赋予了DUMMY,确保你的数据库实例名没有使用DUMMY,否则过滤不掉。
  d、监控脚本在监控过程中只要有一个实例宕掉,则发送整个监控报告。
  d、使用了sendEmail邮件发送程序来发送邮件。参阅:不可或缺的 sendEmail  e、尾部清除监控过程中产生的保留日期之前的日志。

转:http://blog.csdn.net/leshami/article/details/8563115

Linux/Unix shell 监控Oracle实例(monitor instance)的更多相关文章

  1. Linux/Unix shell 监控Oracle监听器(monitor listener)

    使用shell脚本实现对Oracle数据库的监控与管理将大大简化DBA的工作负担,如常见的对实例的监控,监听的监控,告警日志的监控,以及数据库的备份,AWR report的自动邮件等.本文给出Linu ...

  2. Linux/Unix shell 监控Oracle告警日志(monitor alter log file)

    使用shell脚本实现对Oracle数据库的监控与管理将大大简化DBA的工作负担,如常见的对实例的监控,监听的监控,告警日志的监控,以及数据库的备份,AWR report的自动邮件等.本文给出Linu ...

  3. Linux/Unix shell 自动发送AWR report(二)

    观察Oracle数据库性能,Oracle自带的awr 功能为我们提供了一个近乎完美的解决方案,通过awr特性我们可以随时从数据库提取awr报告.不过awrrpt.sql脚本执行时需要我们提供一些交互信 ...

  4. Linux/Unix shell 脚本中调用SQL,RMAN脚本

    Linux/Unix shell脚本中调用或执行SQL,RMAN 等为自动化作业以及多次反复执行提供了极大的便利,因此通过Linux/Unix shell来完成Oracle的相关工作,也是DBA必不可 ...

  5. Linux/Unix shell sql 之间传递变量

    灵活结合Linux/Unix Shell 与SQL 之间的变量传输,极大程度的提高了DBA的工作效率,本文针对Linux/Unix shell sql 之间传递变量给出几个简单的示例以供参考. Lin ...

  6. Linux Unix 环境变量设置实例

    背景 从第一次写Hello World我们便开始接触环境变量.这最基础的系统设置是必须要掌握的,尤其在是Linux/Unix系统中.比如,哪天某个Java进程出现问题,我们想分析一下其线程堆栈,却发现 ...

  7. Linux/Unix shell 脚本监控磁盘可用空间

    Linux下监控磁盘的空闲空间的shell脚本,对于系统管理员或DBA来说,必不可少.下面是给出的一个监控磁盘空间空间shell脚本的样本,供大家参考. 1.监控磁盘的空闲空间shell脚本 robi ...

  8. Linux/UNIX环境下Oracle数据库多实例开机启动脚本(转)

    操作系统平台:RHEL 5Shell环境:BashOracle:10g2 功能描述:开机时自动切换到oracle用户下,启动oracle的多个实例.并记录数据库的启动情况到自定义的日志文件中. #!/ ...

  9. Linux/Unix shell 自动发送AWR report

    观察Oracle数据库性能,Oracle自带的awr 功能为我们提供了一个近乎完美的解决方案,通过awr特性我们可以随时从数据库提取awr报告.不过awrrpt.sql脚本执行时需要我们提供一些交互信 ...

随机推荐

  1. C# Task的使用---Task的启动

    .NET 4.0包含的新名称空间System.Threading.Tasks,它包含的类抽象出了线程功能.任务表示应完成的某个单元的工作.这个单元的工作可以在单独的线程中运行,也可以以同步的方式启动一 ...

  2. 李洪强iOS开发之OC语言基础知识

    OC语言基础知识 一.面向对象 OC语言是面向对象的,c语言是面向过程的,面向对象和面向过程只是解决问题的两种思考方式,面向过程关注的是解决问题涉及的步骤,面向对象关注的是设计能够实现解决问题所需功能 ...

  3. Linux基础--文件与目录管理

    1.目录与路径 1)特殊目录 .   代表此层目录 ..  代表上一层目录 -   代表前一个工作目录 ~   代表『目前使用者身份』所在的家目录 ~account   代表account这个使用者的 ...

  4. 浅析c语言中的变量(局部变量,外部变量,静态变量,寄存器变量)[转]

    c语言中变量分为四类,分别是 1.auto   自动变量 2.static   静态存贮分配变量(又分为内部静态和外部静态) 3.extern  全程变量(用于外部变量说明) 4.register   ...

  5. 改变dijit的长度的心得

    改变dijit的长度要进入到里面改 如dijit/form/Select   (以table的方式来组合控件) 改变的时候,先找到dijitButtonContent 然后在后面样式文件里写就可以了 ...

  6. Win软件私家珍藏-常用软件工具使用总结

    原文:Win软件私家珍藏-常用软件工具使用总结 Windowns常用软件 看图 FastStoneImageViewer 免费软件,好用到爆!没广告!功能齐全!不光能看图,还能修图! Picasa3 ...

  7. *在Win7中安装JDK1.7并配置环境变量

    安装的过程就不废话了. 下面是环境变量的配置. 1. 配置环境变量 单机右键‘计算机--属性’  2.点击高级系统设置  3.点击‘环境变量’ 4.增加"JAVA_HOME"系统变 ...

  8. CentOS中通过stat查看文件的元数据

    CentOS中可以通过stat查看文件的元数据 [baby@xiaoxiao abc]$ stat honey  File: `honey'  Size: 25         Blocks: 8   ...

  9. 应用scikit-learn做文本分类

    文本挖掘的paper没找到统一的benchmark,只好自己跑程序,走过路过的前辈如果知道20newsgroups或者其它好用的公共数据集的分类(最好要所有类分类结果,全部或取部分特征无所谓)麻烦留言 ...

  10. dojo 二 AMD模块

    可参考官方教程:http://dojotoolkit.org/documentation/tutorials/1.7/hello_dojo/教程里主要定义了两个方法,setText设置文本内容和res ...