Я выясняю, почему служба (solr) не запускается при загрузке сервера (в данном случае это бродячая коробка, работающая под управлением Ubuntu 12.04).
Сценарий выполняется, если я запускаю /etc/init.d/solr start
Я запускаю sudo update-rc.d solr по умолчанию, но он не запускается после загрузки, и теперь я не знаю, как это сделать.
Какие у меня варианты отладки?
Сценарий:
#! /bin/sh
### BEGIN INIT INFO
# Provides: solr
# Required-Start: $all
# Required-Stop: $all
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Starts solr
# Description: Starts solr using start-stop-daemon
### END INIT INFO
SOLR_HOME=/vagrant/solr/jetty
DAEMON=/usr/bin/java
DAEMON_OPTS='-jar start.jar'
NAME=Solr
DESC=Solr
PID_FILE=/vagrant/solr/jetty/$NAME.pid
SOLR_USER=vagrant
SOLR_GROUP=vagrant
test -x $DAEMON || exit 1
set -e
. /lib/lsb/init-functions
case "$1" in
start)
echo -n "Starting $DESC: "
if start-stop-daemon -d $SOLR_HOME --start -b -m --pidfile $PID_FILE --user $SOLR_USER --group $SOLR_GROUP --chuid $SOLR_USER --startas $DAEMON -- $DAEMON_OPTS
then
echo "solr started" >> /var/log/messages
exit 0
else
echo "solr start failed" >> /var/log/messages
exit 1
fi
;;
stop)
echo -n "Stopping $DESC: "
if start-stop-daemon --stop --pidfile $PID_FILE
then
echo "stopped."
exit 0
else
echo "failed."
exit 1
fi
;;
restart|force-reload)
${0} stop
sleep 0.5
${0} start
;;
status)
status_of_proc -p $PID_FILE "$DAEMON" solr && exit 0 || exit $?
;;
*)
N=/etc/init.d/$NAME
echo "Usage: $N {start|stop|restart|force-reload}" >&2
exit 1
;;
esac
exit 0
Вывод в /var /log /messages (два раза!) solr started
...