最常见的监视任务就是监视整个文件系统。通过一些简单的命令可以将df -k中的可用字段截取出来用来监控监本

首先 df -k

本地存储监控的网络结构 本地监控系统_字段

为了截取有效字段而排除tmpfs的干扰:

tips:LINUX中可以把一些程序的临时文件放置在tmpfs中,利用tmpfs比硬盘速度快的特点提升系统性能。tmpfs是一种虚拟内存文件系统,而不是块设备。是基于内存的文件系统,创建时不需要使用mkfs等初始化

 

本地存储监控的网络结构 本地监控系统_sed_02

接下来只要文件系统 、已用的百分比、挂载点这几个字段可以使用awk

之后对这些内容进行判断

本地存储监控的网络结构 本地监控系统_sed_03


之后就可以写自己的脚本了


#!/bin/bash
#############################################################
# File Name:file_system_monitor.sh
# Author:Nicolas Cage
# mail:454041823@qq.com
# Created Time: 2016年09月29日 星期四 20时49分04秒
#====================================================
#

tty_init=`tput clear`

FSMAX=85

WORKFILE="/tmp/df.work"
>$WORKFILE
OUTFILE="/tmp/df.outfile"
>$OUTFILE
thishost=`hostname`

df -k|sed '1d'|grep -v tmpfs|awk '{print $1,$5,$6}'|sed 's/%//g'>$WORKFILE

while read fsdevice fsvalue fsmount
do
        typeset -i fsvalue
        if [ ${fsvalue} -gt $FSMAX ]
        then 
                echo "${fsdevice} mounted on ${fsmount} is ${fsvalue}%" \
                        >>$OUTFILE
        fi

done < $WORKFILE

if [[ -s $OUTFILE ]]
then        echo -e  "\nFull Filesystem(s) on $thishost\n"
        cat $OUTFILE
fi



为了完善脚本,可以人为指定一个FSMAX。

有时候不同的文件系统要求不同的FSMAX,所以可以设置一个可供用户选择的FSMAX。

exceptions文件

在一个文件里规定想要监视的文件的FSMAX值



BINDIR="/usr/local/bin"           #选一个存放规定FSMAX值的文件的路径(可随便选)

EXCEPTIONS="${BINDIR}/exceptions"#exception文件

DATA_EXCEPTION="/tmp/dfdata.out"#异常监测结果

#!/bin/bash
#############################################################
# File Name:file_system_monitor.sh
# Author:Nicolas Cage
# Created Time: 2016年09月29日 星期四 20时49分04秒
#====================================================
#

tty_init=`tput clear`

FSMAX=85

WORKFILE="/tmp/df.work"
>$WORKFILE
OUTFILE="/tmp/df.outfile"
>$OUTFILE
thishost=`hostname`

BINDIR="/usr/local/bin"           #选一个存放规定FSMAX值的文件的路径(可随便选)
EXCEPTIONS="${BINDIR}/exceptions"                       #exception文件
DATA_EXCEPTION="/tmp/dfdata.out"                        #异常监测结果

function load_EXCEPTIONS_file
{
        cat $EXCEPTIONS|grep -v "^$"|sed '/^$/d' > $DATA_EXCEPTION
}

function check_exceptions
{
        while read FSNAME NEW_MAX
        do
                if [[ $FSNAME == $FSMOUNT ]];then
                        NEW_MAX=`echo "$NEW_MAX" |sed 's/\%//g'`
                        if [ $FSVALUE -gt $NEW_MAX ]
                        then
                                return 0
                        fi
                fi
        done<$DATA_EXCEPTION
        return 1 #NOT found in file
}

[[ -s $EXCEPTIONS ]] && load_EXCEPTIONS_file

df -k|sed '1d'|grep -v tmpfs|awk '{print $1,$5,$6}'|sed 's/\%//g'>$WORKFILE

while read FSDEVICE FSVALUE FSMOUNT
do

        FSVALUE=`echo $FSVALUE | sed s/\%//g`
        typeset -i FSVALUE
        if [[ -s $EXCEPTIONS ]];then
                check_exceptions
                RC=$?
                if [ $RC -eq 0 ];then
                                echo "$FSDEVICE mount on $FSMOUNT is ${FSVALUE}%" >> $OUTFILE
                elif [ $RC -eq 1 ];then
                        if [ $FSVALUE -gt $FSMAX ];then
                                echo "$FSDEVICE mount on $FSMOUNT is ${FSVALUE}%" >> $OUTFILE
                        fi
                fi
        fi
        if [ $FSVALUE -gt $FSMAX ];then
                echo "$FSDEVICE mount on $FSMOUNT is ${FSVALUE}%" >> $OUTFILE
        fi
done < $WORKFILE
if [[ -s $OUTFILE ]]
then
        echo -e  "\nFull Filesystem(s) on $thishost\n"
        cat $OUTFILE
fi

rm -r ${DATA_EXCEPTION}




 cat $EXCEPTIONS|grep -v "^$"|sed '/^$/d' > $DATA_EXCEPTIONS  #这句是为了避开注释行,删点空行,将用户定义的FSMAX值加载进去


[[ -s $EXCEPTION ]] && load_EXCEPTIONS_file   ##如果有EXCEPTION这个文件且不为空再执行新FSMAX

 

这里写了两个函数

function load_EXCEPTIONS_file  #这个函数是为了将exception中的多余行和多余符号去掉

function check_exceptions     #这个函数在监测到exception文件存在后执行,函数内容为读出exception中的新FSMAX值与匹配的FSNAME的值比较

如果等于就返回0,表示危险警告,返回1表示没匹配到FSNAME。