Скрипт init.d работал нормально в Ubuntu 10.10, но не в 11.10, несмотря на исправление заголовка LBS
В Ubuntu 11.10, если я запускаю /usr/bin/cserver -c /etc/cserver.conf, он будет работать нормально.
Но если я запускаю запуск службы cserver или /etc/init.d/cserver, как я делал это 10.10, это не будет. Он просто говорит "запуск cServer", и это последнее, что я слышу об этом.
Вот сценарий:
#!/bin/bash
#
### BEGIN INIT INFO
# Provides: cserver
# Required-Start: $remote_fs $syslog
# Required-Stop: $remote_fs $syslog
# Should-Start: $network $time
# Should-Stop: $network $time
# Default-Start: 3 4 5
# Default-Stop: 0 1 2 6
# Short-Description: Start and stop the cserver server daemon
# Description: Controls the cserver server daemon
### END INIT INFO
#
set -e
set -u
${DEBIAN_SCRIPT_DEBUG:+ set -v -x}
CSERVERDIR=/usr/bin
PROG=./cserver
OPTIONS=" -c /etc/cserver.conf > /dev/null 2>&1 &"
start() {
echo -n "Starting cServer "
cd $CSERVERDIR
daemon $PROG $OPTIONS
RETVAL=$?
echo
return $RETVAL
}
stop() {
CSERVERPID=$(pidof cserver)
if [ $CSERVERPID ] ; then
echo -n "Stopping cServer "
kill $(pidof cserver)
RETVAL=$?
else
echo "cServer not running"
RETVAL=1
fi
echo
return $RETVAL
}
status() {
CSERVERPID=$(pidof cserver)
if [ $CSERVERPID ] ; then
echo -n "cServer is running"
RETVAL=0
else
echo -n "cServer is stopped"
RETVAL=1
fi
echo
return $RETVAL
}
# See how we were called.
RETVAL=0
case "$1" in
start)
start
;;
stop)
stop
;;
restart)
stop
start
;;
status)
status
;;
*)
echo $"Usage: $prog {start|stop|restart|status}"
exit 1
esac
exit $?
Хотя мне никогда не приходилось делать это на исходном сервере, и sysv-rc-conf показывал его в списке и начиная с нужных уровней, я вручную попытался выполнить update-rc.d, и он пожаловался на неверный заголовок lsb, что привело меня к этому вопросу и руководству. Поэтому я изменил заголовок, как указано выше, и вот как это выглядело раньше:
#!/bin/bash
#
#
# chkconfig: 345 99 99
#
# description: cserver init
# processname: cserver
# Source function library.
# . /etc/rc.d/init.d/functions
Теперь есть строка о "библиотеке функций источника", но этот каталог даже не существует, и строка все равно закомментирована.
Я проверил разрешения и символические ссылки на старом сервере, и все кажется идентичным.
Немного ошеломлен и смущен сейчас - может быть, свежая и более проницательная пара глаз может заметить что-то здесь? Благодарю.
ОБНОВЛЕНИЕ и РЕДАКТИРОВАНИЕ: Спасибо kubankczyk - я обратился за вашим предложением о копировании другого, нашел сценарий запуска nginx самым простым и в итоге получил следующее:
#!/bin/sh
### BEGIN INIT INFO
# Provides: cserver
# Required-Start: $local_fs $remote_fs $network $syslog
# Required-Stop: $local_fs $remote_fs $network $syslog
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: starts the cserver server
# Description: starts cserver using start-stop-daemon
### END INIT INFO
PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
DAEMON=/usr/bin/cserver
NAME=cserver
DESC=cserver
DAEMON_OPTS=" -c /etc/cserver.conf"
#test -x $DAEMON || exit 0
set -e
#set -u
#${DEBIAN_SCRIPT_DEBUG:+ set -v -x}
. /lib/lsb/init-functions
case "$1" in
start)
echo -n "Starting $DESC: "
start-stop-daemon --start --quiet --pidfile /var/run/$NAME.pid \
--exec $DAEMON -- $DAEMON_OPTS || true
echo "$NAME."
;;
stop)
echo -n "Stopping $DESC: "
start-stop-daemon --stop --quiet --pidfile /var/run/$NAME.pid \
--exec $DAEMON || true
echo "$NAME."
;;
restart|force-reload)
echo -n "Restarting $DESC: "
start-stop-daemon --stop --quiet --pidfile \
/var/run/$NAME.pid --exec $DAEMON || true
sleep 1
start-stop-daemon --start --quiet --pidfile \
/var/run/$NAME.pid --exec $DAEMON -- $DAEMON_OPTS || true
echo "$NAME."
;;
status)
status_of_proc -p /var/run/$NAME.pid "$DAEMON" cserver && exit 0 || exit $?
;;
*)
echo "Usage: $NAME {start|stop|restart|reload|force-reload|status|configtest}" >&2
exit 1
;;
esac
exit 0
Не уверен, что это правильно, но, по крайней мере, он запускает службу! Благодарю.
1 ответ
Ваш скрипт был написан для chkconfig (такой как используемый в Suse Linux), а не для update-rc.d. Лучшее, что вы можете сделать сейчас (если вы не хотите использовать chkconfig), это выбрать какой-нибудь простой скрипт из вашего /etc/init.d, прочитать его, понять его, скопировать и перейти на запуск cserver.
В частности, убедитесь, что команда "daemon" правильно используется в вашем сценарии вместе с ampersand &.
Начните устранять неисправности с самого простого сценария. Временно измените OPTIONS на OPTIONS=" -c /etc/cserver.conf". Протестируйте только пустой скрипт (если это не работает, service cserver start
не будет работать, является ли заголовок LSB или нет):
su -
export DEBIAN_SCRIPT_DEBUG=1
/etc/init.d/cserver start
(редактировать вопрос с результатами)