Check service.sh : Différence entre versions
De wikiGite
(2 révisions intermédiaires par un autre utilisateur non affichées) | |||
Ligne 5 : | Ligne 5 : | ||
# FSo 2010 | # FSo 2010 | ||
# check services that can't be check by monit (ex : no pid file and no network port) | # check services that can't be check by monit (ex : no pid file and no network port) | ||
− | + | BIN_MAIL=/usr/sbin/sendmail | |
− | # First : | + | SENDER_MAIL=$(hostname -s) |
− | /etc/init.d/monit status > /dev/null 2>&1 | + | REPORT_EMAIL=support@systea.net |
+ | |||
+ | # First : MONIT itself ! | ||
+ | # Debian : | ||
+ | if [ -e /etc/debian_version ] | ||
+ | then | ||
+ | ps -p $(cat /var/run/monit.pid) > /dev/null 2>&1 | ||
+ | else | ||
+ | # CentOS : | ||
+ | /etc/init.d/monit status > /dev/null 2>&1 | ||
+ | fi | ||
if [ $? -ne 0 ] | if [ $? -ne 0 ] | ||
then | then | ||
/etc/init.d/monit restart > /dev/null 2>&1 | /etc/init.d/monit restart > /dev/null 2>&1 | ||
+ | logger "Check_services.sh restarting Monit" | ||
+ | ( | ||
+ | echo "Subject: [Check services] : monit restarted" | ||
+ | echo "" | ||
+ | echo "Status of service :" | ||
+ | monit summary | ||
+ | ) | $BIN_MAIL -F$SENDER_MAIL $REPORT_EMAIL | ||
fi | fi | ||
+ | # OSSEC | ||
# OSSEC don't have standard pid files | # OSSEC don't have standard pid files | ||
OSSEC_DIR=/opt/ossec | OSSEC_DIR=/opt/ossec | ||
OSSECPROC=0 | OSSECPROC=0 | ||
− | for pidfile in $(ls $OSSEC_DIR/var/run/*.pid) | + | ls $OSSEC_DIR/var/run/*.pid > /dev/null 2>&1 |
− | + | if [ $? -eq 0 ] | |
− | + | then | |
− | + | for pidfile in $(ls $OSSEC_DIR/var/run/*.pid) | |
− | + | do | |
− | + | ps -p $(cat $pidfile) | grep ossec > /dev/null 2>&1 | |
− | fi | + | if [ $? -ne 0 ] |
− | + | then | |
+ | OSSECPROC=1 | ||
+ | fi | ||
+ | done | ||
+ | else | ||
+ | OSSECPROC=1 | ||
+ | fi | ||
+ | |||
if [ $OSSECPROC -eq 1 ] | if [ $OSSECPROC -eq 1 ] | ||
then | then | ||
/etc/init.d/ossec restart | /etc/init.d/ossec restart | ||
+ | logger "Check_services.sh restarting Ossec" | ||
+ | ( | ||
+ | echo "Subject: [Check services] : ossec restarted" | ||
+ | echo "" | ||
+ | echo "Status of processes (must return 6 processes running) :" | ||
+ | /etc/init.d/ossec status | ||
+ | ) | $BIN_MAIL -F$SENDER_MAIL $REPORT_EMAIL | ||
fi | fi | ||
Version actuelle datée du 6 avril 2011 à 06:48
Script de surveillance des services qui ne peuvent pas l'être avec monit
(pas de fichier pid, et/ou pas de port réseau à surveiller)
#!/bin/bash # FSo 2010 # check services that can't be check by monit (ex : no pid file and no network port) BIN_MAIL=/usr/sbin/sendmail SENDER_MAIL=$(hostname -s) REPORT_EMAIL=support@systea.net # First : MONIT itself ! # Debian : if [ -e /etc/debian_version ] then ps -p $(cat /var/run/monit.pid) > /dev/null 2>&1 else # CentOS : /etc/init.d/monit status > /dev/null 2>&1 fi if [ $? -ne 0 ] then /etc/init.d/monit restart > /dev/null 2>&1 logger "Check_services.sh restarting Monit" ( echo "Subject: [Check services] : monit restarted" echo "" echo "Status of service :" monit summary ) | $BIN_MAIL -F$SENDER_MAIL $REPORT_EMAIL fi # OSSEC # OSSEC don't have standard pid files OSSEC_DIR=/opt/ossec OSSECPROC=0 ls $OSSEC_DIR/var/run/*.pid > /dev/null 2>&1 if [ $? -eq 0 ] then for pidfile in $(ls $OSSEC_DIR/var/run/*.pid) do ps -p $(cat $pidfile) | grep ossec > /dev/null 2>&1 if [ $? -ne 0 ] then OSSECPROC=1 fi done else OSSECPROC=1 fi if [ $OSSECPROC -eq 1 ] then /etc/init.d/ossec restart logger "Check_services.sh restarting Ossec" ( echo "Subject: [Check services] : ossec restarted" echo "" echo "Status of processes (must return 6 processes running) :" /etc/init.d/ossec status ) | $BIN_MAIL -F$SENDER_MAIL $REPORT_EMAIL fi
A intégrer (par un lien) à /etc/cron.hourly ou /etc/cron.quarter-hourly
cd /etc/cron.hourly/ ln -s /opt/systools/check_services.sh check_services