Chinaunix首页 | 论坛 | 博客
  • 博客访问: 473370
  • 博文数量: 65
  • 博客积分: 2645
  • 博客等级: 少校
  • 技术积分: 675
  • 用 户 组: 普通用户
  • 注册时间: 2006-01-08 17:04
文章分类

全部博文(65)

文章存档

2010年(5)

2009年(5)

2008年(14)

2007年(35)

2006年(6)

分类:

2008-01-31 11:41:26

需求:
    当主机的 /arch, /var, / 目录空间快满时, 向指定的手机发送告警短讯.

需求背景:
   备份设备有问题, 发生了几次数据库归档爆满, 无法登陆数据库登录的情况.

监控实现方式:
    没隔一段时间,执行 bdf 查看主机空间. 如果监控的目录空间使用率大于一个临界点.则向指定的手机发
送告警短讯.

短讯发送方法:
    向接口表中插一条记录(格式要对), 接口程序会自动处理

这是我写的主机空间监控脚本. (接口表名, 表结构, 数据库TNS 已省略 )

#!/usr/bin/sh
#---------------------------------------------------
# check system script
# Author :libin
# Date :2008-01-11
# Version :1.0
# Description: 查詢數據庫空間
# 當指定目錄的空間達到警戒值時, 向指定的號碼發送告警短信
#
#
#---------------------------------------------------

# 監控的目錄 [, 多個目錄以豎線分割]
DISK_SPACE='oracle|arch|var|opt|/$'

# 接收短信號碼 [, 多個號碼以tab分隔]
SVCNUM_LIST="号码1 号码2"

# 主機名
HOSTNAME="数据库主机"


# 臨界點
ERROR=90
WARNING=80
INFO=75
DEBUG=5

# 運行時選取的臨界點
#RUN_LEVEL=${DEBUG}
RUN_LEVEL=${WARNING}


# 向接口表插數據, 發送短信
send_sm()
{
    # 號碼
    local vc_svcnum="$1"

    # 短信信息
    local vc_sminfo="$2"

    # 鏈接數據庫, 發送短信
    $ORACLE_HOME/bin/sqlplus aaa/bbb@ccc <<EOF_SEND_SM
    set linesize 300
    set heading off
    insert into tab_xxx
      (....

       svcnums,

       sminfo,
       ....

     )

    values
      (...,
       '$vc_svcnum',
       ...
       '$vc_sminfo',

       ...);
    commit;
    exit
EOF_SEND_SM
}


# used 由百分比 換為 數值
for bdf_list in `bdf | grep -E $DISK_SPACE | awk '{printf("%s,%s,%s,%s,%d,%s\n",$1,$2,$3,$4,$5,$6)}'`
    do
        filesystem="`echo $bdf_list | awk '{FS=","} {print $1}'`"
        kbytes="`echo $bdf_list | awk '{FS=","} {print $2}'`"
        used="`echo $bdf_list | awk '{FS=","} {print $3}'`"
        avail="`echo $bdf_list | awk '{FS=","} {print $4}'`"
        used="`echo $bdf_list | awk '{FS=","} {print $5}'`"
        mounted_on="`echo $bdf_list | awk '{FS=","} {print $6}'`"

        echo "目錄:"$mounted_on
        echo "使用的空間數:"$used"%"

        if [ $used -ge ${RUN_LEVEL} ]
        then
         # 向列表中的號碼發送告警短信
         for svcnum in $SVCNUM_LIST
         do
         # 短信內容
         message="主機[${HOSTNAME}]空間告警. [WARNING]目錄: ${mounted_on} 空間使用率:${used}%"

         send_sm "$svcnum" "${message}" 1>/dev/null 2>&1
         #echo "[$svcnum]" "${message}"

         sleep 1
         done
        fi
    done

阅读(1707) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~