Outils personnels

Check service.sh : Différence entre versions

De wikiGite

 
(Une révision intermédiaire par un autre utilisateur non affichée)
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)
# First : monit itself !
 
# Debian :
 
 
  BIN_MAIL=/usr/sbin/sendmail
 
  BIN_MAIL=/usr/sbin/sendmail
 
  SENDER_MAIL=$(hostname -s)
 
  SENDER_MAIL=$(hostname -s)
 
  REPORT_EMAIL=support@systea.net
 
  REPORT_EMAIL=support@systea.net
 +
 +
# First : MONIT itself !
 +
# Debian :
 
  if [ -e /etc/debian_version ]
 
  if [ -e /etc/debian_version ]
 
  then
 
  then
Ligne 28 : Ligne 29 :
 
     ) | $BIN_MAIL -F$SENDER_MAIL $REPORT_EMAIL
 
     ) | $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
Ligne 46 : Ligne 48 :
 
     OSSECPROC=1
 
     OSSECPROC=1
 
  fi
 
  fi
 
+
 
  if [ $OSSECPROC -eq 1 ]
 
  if [ $OSSECPROC -eq 1 ]
 
  then
 
  then

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