원문 : http://www.ischo.net -- 조인상 // 시스템 엔지니어

Writer : http://www.ischo.net -- ischo // System Engineer in Replubic Of Korea

+++++++++++++++++++++++++++++++++++++++++++++++++++++++

 

원문 : http://www.ischo.net -- 조인상 //시스템 엔지니어

+++++++++++++++++++++++++++++++++++++++++++++++++++++++

 

프로세스 생사여부 검사후 메일보내는 쉘스크립트

 

먼저 해당 디렉토리의  proclist.txt 파일에 정의된 프로세스 리스트들을 읽어서

생사여부를 검사하고

죽은 프로세스가 있으면 메일로 보내주는 스크립트

 

완전하진 않지만 그럭저럭 쓸만함.

 

 

 

 

#!/bin/ksh

######################################################################################
# script by ischo.
# http://www.ischo.net
# mail:chosim1@naver.com
# script description :
# This script read first $PROG_HOME/proclist.txt file, then check process.
# If exist died process, make Mail Contents and send mail to $MAIL_RECIEVER
######################################################################################


######################################################################################
## ENVIRONMENT SETTING - You can edit this.
######################################################################################

# Absolute Path of script
PROG_HOME=/root/chkproc

# E-mail reciever
MAIL_RECIEVER=chosim1@naver.com

######################################################################################
######################################################################################

 

 

######################################################################################
# Variables for host environment - You do not need to edit.
######################################################################################

# ServerName : This setting will be included in SMS
SERVERNAME=`hostname`

# Config File List
MAILFILE=${PROG_HOME}/chkproc.mail
LOGFILE=${PROG_HOME}/chkproc_`date +%Y%m%d`.log
PROCLIST=${PROG_HOME}/proclist.txt
ALIVEFILE=${PROG_HOME}/alive_proclist.tmp
LASTSTATFILE=${PROG_HOME}/laststat.tmp
CURSTATFILE=${PROG_HOME}/curstat.tmp
TEMPSTATFILE=${PROG_HOME}/tempstat.tmp


# TIME mark VARS
STIME=`date +%Y%m%d%H%M%S`
TTIME=`date +%H:%M`
DDATE=`date +%Y%m%d`

# First VAR's value for Operation
ERROR=0
NOPROC=`cat ${PROCLIST} | wc -l`
Recover_stat="no"
Down_stat="no"

# First creation of LASTSTATFILE
if [ -f ${LASTSTATFILE} ];
then
        touch ${LASTSTATFILE}
else
        for TEMP in `cat ${PROCLIST}`
        do
        echo "${TEMP} : DOWN" >> ${LASTSTATFILE}
        done
fi

cat /dev/null > ${CURSTATFILE}

######################################################################################
######################################################################################

 

 

######################################################################################
# DEFINE FUNCTIONS
######################################################################################
# Function SendMail - Sending Mail of Error
function Func_SendMail
{


for PROCNAME in `cat ${PROCLIST}`
do

        CURRENT_STAT=`cat ${CURSTATFILE} | grep ${PROCNAME} | awk '{print $3}'`
        LAST_STAT=`cat ${LASTSTATFILE} | grep ${PROCNAME} | awk '{print $3}'`

        if [ ${CURRENT_STAT} = UP ];
        then
                if [ ${LAST_STAT} = DOWN ];
                then
                Recover_stat="yes"
                fi
                cat ${LASTSTATFILE} | grep -v ${PROCNAME} > ${TEMPSTATFILE}
                cat ${TEMPSTATFILE} > ${LASTSTATFILE}
                echo "${PROCNAME} : UP" >> ${LASTSTATFILE}
        else
                if [ ${LAST_STAT} = UP ];
                then
                Down_stat="yes"
                fi
                cat ${LASTSTATFILE} | grep -v ${PROCNAME} > ${TEMPSTATFILE}
                cat ${TEMPSTATFILE} > ${LASTSTATFILE}
                echo "${PROCNAME} : DOWN" >> ${LASTSTATFILE}
        fi

done

if [ ${Down_stat} = yes ];
then
mail -s "Process Down Alert!" ${MAIL_RECIEVER} < ${MAILFILE}
fi

if [ ${Recover_stat} = yes ];
then
echo "mail -s 'Process Recovered!' ${MAIL_RECIEVER} < ${MAILFILE}"
mail -s "Process Recovered!" ${MAIL_RECIEVER} < ${MAILFILE}
fi

}

 

# Function LogTop - Logging Number of Alive Processes
function Func_LogTop
{
NOP=0
cat /dev/null > ${ALIVEFILE}

for TEMP_PROC in `cat ${PROCLIST}`
do

        for REAL_PROC in `ps -ef | grep ${TEMP_PROC} | grep -v grep | awk {'print $8'} | sort | uniq`
        do
                if [ ${TEMP_PROC} = ${REAL_PROC} ];
                then
                ps -ef | grep ${TEMP_PROC} | grep -v grep | awk {'print $8'} | sort | uniq >> ${ALIVEFILE}
                NOP=`expr ${NOP} + 1`
                fi
        done

done

echo "${DDATE} ${TTIME}  Number of alive Processes : ${NOP}/${NOPROC}" >> ${LOGFILE}
}

 

# Function Logging - Log Process Check Result
function Func_Logging
{
echo "${DDATE} ${TTIME}  --Process ${PROC} Down" >> ${LOGFILE}
}


# Function LogBottom - Log Bottom Message
function Func_LogBottom
{
cat /dev/null > ${ALIVEFILE}

if [ ${ERROR} -eq 1 ];
then
echo "ps -ef result :" >> ${LOGFILE}
cat ${ALIVEFILE}  >> ${LOGFILE}
fi

}

 

#############################################################################################
#############################################################################################

 


#############################################################################################
# Main Procedure
# - Start Program
#############################################################################################

echo "-- ${DDATE} ${TTIME}  ${SERVERNAME} Process Check List --" > $MAILFILE


# Logging Number of Alive Processes
Func_LogTop


# Loop Process check and Log
for PROC in `cat $PROCLIST`
do

PROC_CHECK=`ps -ef | grep $PROC | grep -v grep | wc -l`
SEND_MSG=`echo "[critical] $SERVERNAME Process $PROC Down. $TTIME"`

        if [ $PROC_CHECK -eq 0 ];
        then

        echo "-- Process $PROC Down. ${TTIME}" >> $MAILFILE
        echo "${PROC} : DOWN" >> ${CURSTATFILE}
        Func_Logging
        ERROR=1

        else
        {
        echo "-- Process $PROC alive. ${TTIME}" >> $MAILFILE
        echo "${PROC} : UP" >> ${CURSTATFILE}
        }

        fi

done

# Send Mail
Func_SendMail


# Maintain Number of LOG files
find ${PROG_HOME} -name "*.log" -type f -mtime +5 -exec rm {} \;

 

 

번호 제목 글쓴이 날짜 조회 수
공지 [공지] 게시자료 열람자유. 불펌금지입니다. 조인상 2010.12.07 30770
84 백스페이스 눌러서 지우려고 할때 ^H 표시될때 조치법 조인상 2010.05.12 24526
83 centOS 4.2 설치시 한글깨짐 문제 조인상 2010.05.12 18468
82 sendmail 기반의 Squirrelmail (다람쥐메일)설치기법 조인상 2010.05.12 13170
81 centOS 에서 dovecot POP3 사용하기 조인상 2010.05.12 15241
80 sendmail 25번포트 접속이 localhost에서만 허용될때 조인상 2010.05.12 16946
79 랜카드 동작속도 확인/수정 방법 조인상 2010.05.12 29496
78 tar 를 이용한 테잎 백업스크립트 예 조인상 2010.05.12 10982
77 [펌] 리눅스에서의 시리얼통신 조인상 2010.05.12 19999
76 xinetd 모드로 proftpd 변경 조인상 2010.05.12 12364
75 ssh 자동로그아웃 설정방법 조인상 2010.05.12 41532
74 파일로 스왑추가 방법 조인상 2010.05.12 11097
73 vsftpd 포트변경 방법 조인상 2010.05.12 14866
72 LVM 사용하여 추가한 디스크로 볼륨 늘리기 ischo 2010.05.19 35806
71 리눅스환경에서 RedOwl 정지시키기 조인상 2010.05.27 14492
70 case로 만드는 오라클 서비스 관리 ksh 스크립트 예제 ischo 2010.06.18 13494
69 CentOS에 zabbix 1.8.2 install secret 조인상 2010.07.27 2
68 HOW TO SELinux file ischo 2010.11.17 9351
67 Linux Performance and Tuning Guidelines - IBM file ischo 2010.11.17 9793
66 시스템 관리자를 위한 50가지 비법 조인상 2011.01.04 12215
65 불특정 파일리스트 FTP 전송 스크립트 file ischo 2011.02.18 14179
서버에 요청 중입니다. 잠시만 기다려 주십시오...