150 lines
2.8 KiB
Bash
150 lines
2.8 KiB
Bash
#!/bin/bash
|
|
#
|
|
# xend Starts and stops the Xen management daemon
|
|
#
|
|
# chkconfig: 35 98 01
|
|
# description: Starts and stops the Xen management daemon
|
|
#
|
|
### BEGIN INIT INFO
|
|
# Provides: xend
|
|
# Required-Start: $syslog
|
|
# Should-Start: $time $network $remote_fs
|
|
# Required-Stop: $syslog
|
|
# Should-Stop: $time $network $remote_fs
|
|
# Default-Start: 3 5
|
|
# Default-Stop: 0 1 2 4 6
|
|
# Short-Description: Starts and stops the Xen management daemon
|
|
# Description: Starts and stops the Xen management daemon. xend is needed
|
|
# to create and manage VMs on Xen.
|
|
### END INIT INFO
|
|
|
|
. /etc/rc.status
|
|
rc_reset
|
|
|
|
XEND=`ps ax | grep -w xend | grep -w python | awk '{ print $1 }'`
|
|
XEND=`echo $XEND`
|
|
|
|
await_daemons_up()
|
|
{
|
|
i=1
|
|
rets=10
|
|
xend status
|
|
while [ $? -ne 0 -a $i -lt $rets ]; do
|
|
sleep 1
|
|
echo -n .
|
|
i=$(($i + 1))
|
|
xend status
|
|
done
|
|
}
|
|
|
|
xend_abort()
|
|
{
|
|
echo -n "xend "
|
|
rc_failed $1
|
|
rc_status -v
|
|
rc_exit
|
|
}
|
|
|
|
cleanup()
|
|
{
|
|
rm -f /var/lib/xen/tmp/* 2>/dev/null
|
|
rm -f /var/lib/xen/xenbl* 2>/dev/null
|
|
}
|
|
|
|
check()
|
|
{
|
|
if [ "$1" == status ]; then
|
|
if [ ! -e /proc/xen/capabilities ]; then
|
|
xend_abort 3
|
|
fi
|
|
else
|
|
if [ `id -u` != 0 ]; then
|
|
xend_abort 4
|
|
fi
|
|
if [ ! -e /proc/xen/capabilities ] ||
|
|
! grep control_d /proc/xen/capabilities >/dev/null 2>&1; then
|
|
if [ "$1" == stop ] ||
|
|
[ "$1" == try-restart ]; then
|
|
xend_abort 0
|
|
else
|
|
xend_abort 6
|
|
fi
|
|
fi
|
|
fi
|
|
}
|
|
|
|
case "$1" in
|
|
start)
|
|
check $1
|
|
echo -n "Starting xend "
|
|
if [ ! -z "$XEND" ]; then
|
|
echo -n "(already running pid $XEND) "
|
|
else
|
|
cleanup
|
|
fi
|
|
# Load XEN backend modules
|
|
# Sidenote: They could be loaded later:
|
|
# - netloop at network-bridge init time
|
|
# - netbk and blkbk when the dom0 hotplug events occur
|
|
# (in xen-network-common.sh and block-common.sh)
|
|
# - xenblk when xend prepares for bootloader
|
|
# but for now it's safest to have them loaded when xend starts in dom0.
|
|
modprobe blktap 2>/dev/null || true
|
|
modprobe blkbk 2>/dev/null || true
|
|
modprobe xenblk 2>/dev/null || true
|
|
modprobe netloop 2>/dev/null || true
|
|
modprobe netbk 2>/dev/null || true
|
|
xend start
|
|
await_daemons_up
|
|
;;
|
|
stop)
|
|
check $1
|
|
echo -n "Stopping xend "
|
|
if [ -z "$XEND" ]; then
|
|
echo -n "(not running) "
|
|
xend stop
|
|
rc_reset
|
|
else
|
|
echo -n "(pid $XEND) "
|
|
xend stop
|
|
cleanup
|
|
rc_reset
|
|
fi
|
|
;;
|
|
status)
|
|
check $1
|
|
echo -n "Checking status of xend "
|
|
if [ ! -z "$XEND" ]; then
|
|
echo -n "(pid $XEND) "
|
|
fi
|
|
xend status
|
|
;;
|
|
restart|reload)
|
|
check $1
|
|
echo -n "Restarting xend "
|
|
if [ -z "$XEND" ]; then
|
|
echo -n "(not running) "
|
|
else
|
|
echo -n "(old pid $XEND) "
|
|
fi
|
|
xend restart
|
|
await_daemons_up
|
|
;;
|
|
try-restart)
|
|
check $1
|
|
$0 status
|
|
if [ $? = 0 ]; then
|
|
$0 restart
|
|
else
|
|
rc_reset
|
|
fi
|
|
;;
|
|
*)
|
|
echo "Usage: $0 {start|stop|restart|try-restart|reload|status}"
|
|
rc_failed 2
|
|
rc_exit
|
|
esac
|
|
|
|
rc_status -v
|
|
rc_exit
|