2010-01-15 23:47:52 +03:00
#!/bin/bash
#
# chkconfig: - 22 78
2010-01-19 05:04:33 +03:00
# description: Starts and stops cmirrord
2010-01-15 23:47:52 +03:00
#
2010-01-19 05:04:33 +03:00
# For Red-Hat-based distributions such as Fedora, RHEL, CentOS.
2010-01-15 23:47:52 +03:00
#
### BEGIN INIT INFO
# Provides: cmirrord
2010-01-19 05:04:33 +03:00
# Required-Start: $network $time $local_fs
# Required-Stop: $network $time $local_fs
2010-01-15 23:47:52 +03:00
# Short-Description: Starts and stops cmirrord
2010-01-19 05:04:33 +03:00
# Description: Starts and stops the cluster mirror log daemon
2010-01-15 23:47:52 +03:00
### END INIT INFO
. /etc/init.d/functions
2010-01-19 05:04:33 +03:00
DAEMON=cmirrord
LOCK_FILE="/var/lock/subsys/$DAEMON"
2010-01-15 23:47:52 +03:00
start()
{
2010-01-19 05:04:33 +03:00
if ! pidof $DAEMON > /dev/null
then
echo -n "Starting $DAEMON: "
2010-01-22 19:19:38 +03:00
daemon $DAEMON
2010-01-19 05:04:33 +03:00
rtrn=$?
echo
2010-01-22 19:19:38 +03:00
fi
2010-01-15 23:47:52 +03:00
2010-01-19 05:04:33 +03:00
return $rtrn
}
stop()
{
echo -n "Stopping $DAEMON:"
killproc $DAEMON -TERM
2010-01-15 23:47:52 +03:00
rtrn=$?
2010-01-22 19:19:38 +03:00
echo
2010-01-16 00:48:03 +03:00
return $rtrn
2010-01-15 23:47:52 +03:00
}
2010-01-19 05:04:33 +03:00
wait_for_finish()
2010-01-15 23:47:52 +03:00
{
2010-01-19 05:04:33 +03:00
count=0
while [ "$count" -le 10 -a -n "`pidof $DAEMON`" ]
do
2010-01-16 00:48:03 +03:00
sleep 1
2010-01-19 05:04:33 +03:00
count=$((count + 1))
2010-01-15 23:47:52 +03:00
done
2010-01-19 05:04:33 +03:00
if [ `pidof $DAEMON` ]
then
2010-01-16 00:48:03 +03:00
return 1
2010-01-15 23:47:52 +03:00
else
2010-01-19 05:04:33 +03:00
return 0
2010-01-15 23:47:52 +03:00
fi
}
cmirror_status()
{
2010-01-19 05:04:33 +03:00
status $DAEMON
2010-01-15 23:47:52 +03:00
}
rtrn=1
# See how we were called.
case "$1" in
2010-01-16 00:48:03 +03:00
start)
start
rtrn=$?
2010-01-19 05:04:33 +03:00
[ $rtrn = 0 ] && touch $LOCK_FILE
2010-01-16 00:48:03 +03:00
;;
stop)
stop
rtrn=$?
2010-01-19 05:04:33 +03:00
[ $rtrn = 0 ] && rm -f $LOCK_FILE
2010-01-16 00:48:03 +03:00
;;
restart)
2010-01-19 05:04:33 +03:00
if stop
then
wait_for_finish
start
fi
2010-01-16 00:48:03 +03:00
rtrn=$?
;;
status)
cmirror_status
rtrn=$?
if [ $rtrn -eq 0 ]; then
echo "cmirror is running."
fi
;;
*)
echo $"Usage: $0 {start|stop|restart|status}"
;;
2010-01-15 23:47:52 +03:00
esac
exit $rtrn