2013-05-03 13:39:31 +02:00
|
|
|
#!/bin/sh
|
2013-02-04 12:43:16 +01:00
|
|
|
#
|
|
|
|
# chkconfig: 35 90 12
|
|
|
|
# description: Icinga 2
|
|
|
|
#
|
|
|
|
### BEGIN INIT INFO
|
|
|
|
# Provides: icinga2
|
|
|
|
# Required-Start: $remote_fs $syslog
|
|
|
|
# Required-Stop: $remote_fs $syslog
|
2014-04-29 17:26:39 +02:00
|
|
|
# Should-Start: mysql postgresql
|
|
|
|
# Should-Stop: mysql postgresql
|
2013-11-27 14:10:46 +01:00
|
|
|
# Default-Start: 2 3 5
|
2013-02-04 12:43:16 +01:00
|
|
|
# Default-Stop: 0 1 6
|
2013-08-16 17:06:37 +02:00
|
|
|
# Short-Description: icinga2 host/service/network monitoring and management system
|
|
|
|
# Description: Icinga 2 is a monitoring and management system for hosts, services and networks.
|
2013-02-04 12:43:16 +01:00
|
|
|
### END INIT INFO
|
|
|
|
|
2013-11-03 13:45:26 +01:00
|
|
|
DAEMON=@CMAKE_INSTALL_FULL_SBINDIR@/icinga2
|
|
|
|
ICINGA2_CONFIG_FILE=@CMAKE_INSTALL_FULL_SYSCONFDIR@/icinga2/icinga2.conf
|
2013-11-25 17:35:44 +01:00
|
|
|
ICINGA2_STATE_DIR=@CMAKE_INSTALL_FULL_LOCALSTATEDIR@
|
|
|
|
ICINGA2_PID_FILE=$ICINGA2_STATE_DIR/run/icinga2/icinga2.pid
|
|
|
|
ICINGA2_ERROR_LOG=$ICINGA2_STATE_DIR/log/icinga2/error.log
|
2014-06-12 16:05:45 +02:00
|
|
|
ICINGA2_STARTUP_LOG=$ICINGA2_STATE_DIR/log/icinga2/startup.log
|
2014-03-17 18:06:23 +01:00
|
|
|
ICINGA2_LOG=$ICINGA2_STATE_DIR/log/icinga2/icinga2.log
|
2013-11-03 13:45:26 +01:00
|
|
|
ICINGA2_USER=@ICINGA2_USER@
|
|
|
|
ICINGA2_GROUP=@ICINGA2_GROUP@
|
2013-11-25 17:35:44 +01:00
|
|
|
ICINGA2_COMMAND_USER=@ICINGA2_COMMAND_USER@
|
|
|
|
ICINGA2_COMMAND_GROUP=@ICINGA2_COMMAND_GROUP@
|
2013-02-04 12:43:16 +01:00
|
|
|
|
|
|
|
test -x $DAEMON || exit 0
|
|
|
|
|
|
|
|
if [ ! -e $ICINGA2_CONFIG_FILE ]; then
|
|
|
|
echo "Config file '$ICINGA2_CONFIG_FILE' does not exist."
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Get function from functions library
|
2013-09-27 19:41:08 +02:00
|
|
|
if [ -f /etc/rc.d/init.d/functions ]; then
|
|
|
|
. /etc/rc.d/init.d/functions
|
|
|
|
elif [ -f /etc/init.d/functions ]; then
|
2013-02-04 12:43:16 +01:00
|
|
|
. /etc/init.d/functions
|
|
|
|
fi
|
|
|
|
|
2013-09-27 19:41:08 +02:00
|
|
|
# Load extra environment variables
|
|
|
|
if [ -f /etc/sysconfig/icinga ]; then
|
|
|
|
. /etc/sysconfig/icinga
|
|
|
|
fi
|
|
|
|
if [ -f /etc/default/icinga ]; then
|
|
|
|
. /etc/default/icinga
|
|
|
|
fi
|
|
|
|
|
2014-06-12 16:05:45 +02:00
|
|
|
check_run() {
|
2013-11-25 17:35:44 +01:00
|
|
|
mkdir -p $(dirname -- $ICINGA2_PID_FILE)
|
2013-11-26 14:21:40 +01:00
|
|
|
chown $ICINGA2_USER:$ICINGA2_GROUP $(dirname -- $ICINGA2_PID_FILE)
|
2014-06-12 16:05:45 +02:00
|
|
|
if [ -f $ICINGA2_PID_FILE ]; then
|
|
|
|
chown $ICINGA2_USER:$ICINGA2_GROUP $ICINGA2_PID_FILE
|
|
|
|
fi
|
2013-11-26 14:21:40 +01:00
|
|
|
|
2013-11-25 17:35:44 +01:00
|
|
|
mkdir -p $(dirname -- $ICINGA2_ERROR_LOG)
|
2013-11-26 14:21:40 +01:00
|
|
|
chown $ICINGA2_USER:$ICINGA2_COMMAND_GROUP $(dirname -- $ICINGA2_ERROR_LOG)
|
|
|
|
chmod 750 $(dirname -- $ICINGA2_ERROR_LOG)
|
2014-06-12 16:05:45 +02:00
|
|
|
if [ -f $ICINGA2_ERROR_LOG ]; then
|
|
|
|
chown $ICINGA2_USER:$ICINGA2_COMMAND_GROUP $ICINGA2_ERROR_LOG
|
|
|
|
fi
|
|
|
|
if [ -f $ICINGA2_LOG ]; then
|
|
|
|
chown $ICINGA2_USER:$ICINGA2_COMMAND_GROUP $ICINGA2_LOG
|
|
|
|
fi
|
2013-11-25 17:35:44 +01:00
|
|
|
|
|
|
|
mkdir -p $ICINGA2_STATE_DIR/run/icinga2/cmd
|
|
|
|
chown $ICINGA2_USER:$ICINGA2_COMMAND_GROUP $ICINGA2_STATE_DIR/run/icinga2/cmd
|
|
|
|
chmod 2755 $ICINGA2_STATE_DIR/run/icinga2/cmd
|
2014-06-12 16:05:45 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
# Start Icinga 2
|
|
|
|
start() {
|
|
|
|
printf "Starting Icinga 2: "
|
2013-03-12 11:48:45 +01:00
|
|
|
|
2014-06-12 16:05:45 +02:00
|
|
|
if ! $DAEMON -c $ICINGA2_CONFIG_FILE -d -e $ICINGA2_ERROR_LOG -u $ICINGA2_USER -g $ICINGA2_GROUP > $ICINGA2_STARTUP_LOG 2>&1; then
|
|
|
|
echo "Error starting Icinga. Check '$ICINGA2_STARTUP_LOG' for details."
|
2014-04-14 00:16:48 +02:00
|
|
|
exit 1
|
|
|
|
else
|
|
|
|
echo "Done"
|
|
|
|
fi
|
2013-02-04 12:43:16 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
# Restart Icinga 2
|
|
|
|
stop() {
|
|
|
|
printf "Stopping Icinga 2: "
|
2014-06-12 16:05:45 +02:00
|
|
|
|
2013-02-04 12:43:16 +01:00
|
|
|
if [ ! -e $ICINGA2_PID_FILE ]; then
|
|
|
|
echo "The PID file '$ICINGA2_PID_FILE' does not exist."
|
2013-10-14 18:02:37 +02:00
|
|
|
if [ "x$1" = "xnofail" ]; then
|
|
|
|
return
|
|
|
|
else
|
|
|
|
exit 1
|
|
|
|
fi
|
2013-02-04 12:43:16 +01:00
|
|
|
fi
|
|
|
|
|
|
|
|
pid=`cat $ICINGA2_PID_FILE`
|
|
|
|
|
2013-03-12 11:48:45 +01:00
|
|
|
if kill -INT $pid >/dev/null 2>&1; then
|
2013-02-04 12:43:16 +01:00
|
|
|
for i in 1 2 3 4 5 6 7 8 9 10; do
|
2013-03-12 16:16:49 +01:00
|
|
|
if ! kill -CHLD $pid >/dev/null 2>&1; then
|
2013-02-04 12:43:16 +01:00
|
|
|
break
|
|
|
|
fi
|
|
|
|
|
|
|
|
printf '.'
|
|
|
|
|
2014-03-17 09:04:19 +01:00
|
|
|
sleep 3
|
2013-02-04 12:43:16 +01:00
|
|
|
done
|
|
|
|
fi
|
2013-03-12 11:48:45 +01:00
|
|
|
|
2013-03-12 16:16:49 +01:00
|
|
|
if kill -CHLD $pid >/dev/null 2>&1; then
|
2013-03-12 11:48:45 +01:00
|
|
|
kill -KILL $pid
|
|
|
|
fi
|
|
|
|
|
2013-02-04 12:43:16 +01:00
|
|
|
echo "Done"
|
|
|
|
}
|
|
|
|
|
2013-08-30 14:27:24 +02:00
|
|
|
# Reload Icinga 2
|
|
|
|
reload() {
|
|
|
|
printf "Reloading Icinga 2: "
|
2014-04-27 21:47:25 +02:00
|
|
|
|
|
|
|
pid=`cat $ICINGA2_PID_FILE`
|
|
|
|
if kill -HUP $pid >/dev/null 2>&1; then
|
2013-08-30 14:27:24 +02:00
|
|
|
echo "Done"
|
2014-04-27 21:47:25 +02:00
|
|
|
else
|
|
|
|
echo "Error: Icinga not running"
|
|
|
|
exit 3
|
2013-08-30 14:27:24 +02:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2013-09-25 12:42:53 +02:00
|
|
|
# Check the Icinga 2 configuration
|
|
|
|
checkconfig() {
|
2014-06-12 16:05:45 +02:00
|
|
|
printf "Checking configuration: "
|
2013-09-25 12:42:53 +02:00
|
|
|
|
2014-06-12 16:05:45 +02:00
|
|
|
if ! $DAEMON -c $ICINGA2_CONFIG_FILE -C -u $ICINGA2_USER -g $ICINGA2_GROUP > $ICINGA2_STARTUP_LOG 2>&1; then
|
2014-05-22 17:26:56 +02:00
|
|
|
if [ "x$1" = "x" ]; then
|
2014-06-12 16:05:45 +02:00
|
|
|
cat $ICINGA2_STARTUP_LOG
|
|
|
|
echo "Icinga 2 detected configuration errors. Check '$ICINGA2_STARTUP_LOG' for details."
|
2014-05-22 17:26:56 +02:00
|
|
|
exit 1
|
|
|
|
else
|
2014-06-12 16:05:45 +02:00
|
|
|
echo "Not "$1"ing Icinga 2 due to configuration errors. Check '$ICINGA2_STARTUP_LOG' for details."
|
2014-05-22 17:26:56 +02:00
|
|
|
if [ "x$2" = "xfail" ]; then
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
fi
|
2014-03-16 23:26:47 +01:00
|
|
|
fi
|
2014-06-12 16:05:45 +02:00
|
|
|
|
|
|
|
echo "Done"
|
|
|
|
# no arguments requires full output
|
|
|
|
if [ "x$1" = "x" ]; then
|
|
|
|
cat $ICINGA2_STARTUP_LOG
|
|
|
|
fi
|
2013-09-25 12:42:53 +02:00
|
|
|
}
|
2013-08-30 14:27:24 +02:00
|
|
|
|
2013-02-04 12:43:16 +01:00
|
|
|
# Print status for Icinga 2
|
|
|
|
status() {
|
|
|
|
printf "Icinga 2 status: "
|
|
|
|
|
|
|
|
pid=`cat $ICINGA2_PID_FILE`
|
2013-05-03 14:49:21 +02:00
|
|
|
if kill -CHLD $pid >/dev/null 2>&1; then
|
2013-02-04 12:43:16 +01:00
|
|
|
echo "Running"
|
|
|
|
else
|
|
|
|
echo "Not running"
|
2014-02-14 16:05:58 +01:00
|
|
|
exit 3
|
2013-02-04 12:43:16 +01:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2014-06-12 16:05:45 +02:00
|
|
|
check_run
|
|
|
|
|
2013-02-04 12:43:16 +01:00
|
|
|
### main logic ###
|
|
|
|
case "$1" in
|
|
|
|
start)
|
2014-03-16 23:26:47 +01:00
|
|
|
checkconfig start fail
|
2013-02-04 12:43:16 +01:00
|
|
|
start
|
|
|
|
;;
|
|
|
|
stop)
|
|
|
|
stop
|
|
|
|
;;
|
|
|
|
status)
|
2013-10-14 18:02:37 +02:00
|
|
|
status
|
2013-02-04 12:43:16 +01:00
|
|
|
;;
|
|
|
|
restart|condrestart)
|
2014-03-16 23:26:47 +01:00
|
|
|
checkconfig restart fail
|
2013-10-14 18:02:37 +02:00
|
|
|
stop nofail
|
2013-02-04 12:43:16 +01:00
|
|
|
start
|
|
|
|
;;
|
2013-09-25 12:42:53 +02:00
|
|
|
reload)
|
2013-08-30 14:27:24 +02:00
|
|
|
reload
|
|
|
|
;;
|
2013-09-25 12:42:53 +02:00
|
|
|
checkconfig)
|
|
|
|
checkconfig
|
|
|
|
;;
|
2013-02-04 12:43:16 +01:00
|
|
|
*)
|
2013-09-27 13:56:11 +02:00
|
|
|
echo "Usage: $0 {start|stop|restart|reload|checkconfig|status}"
|
2013-02-04 12:43:16 +01:00
|
|
|
exit 1
|
|
|
|
esac
|
|
|
|
exit 0
|