
初期化スクリプトが期待どおりに機能し、スタート/ストップ機能が完全に機能するように努力していますが、ステータス機能が期待どおりに機能することはできません。実行中:ディストリビュータID:Debian説明:Debian GNU / Linux 7.6(wheezy)バージョン:7.6コード名:wheezy
これは私の初期化スクリプトです。
#! /bin/sh
### BEGIN INIT INFO
# Provides: graylog-collector
# Required-Start: $network $named $remote_fs $syslog
# Required-Stop: $network $named $remote_fs $syslog
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Graylog Collector
# Description: Graylog's open source log shipper
### END INIT INFO
# Process name ( For display )
NAME="graylog-collector"
# Daemon name, where is the actual executable
DAEMON="/etc/graylog-collector/bin/graylog-collector"
# DAEMON args
DAEMON_OPT="run -f /etc/graylog-collector/config/collector.conf"
# User to run the deamon
DAEMON_USER="graylog-collector"
# pid file for the daemon
PIDDIR="/var/run/$NAME"
PIDFILE="$PIDDIR/$NAME.pid"
PATH="/sbin:/bin:/usr/sbin:/usr/bin"
test -x $DAEMON || exit 0
. /lib/lsb/init-functions
d_start () {
log_daemon_msg "Starting system $NAME Daemon"
if [ ! -e $PIDDIR ] ; then
mkdir $PIDDIR
chown ${DAEMON_USER}:${DAEMON_USER} $PIDDIR
fi
start-stop-daemon --background --start \
--user $DAEMON_USER \
--chuid $DAEMON_USER \
--make-pidfile \
--pidfile $PIDFILE \
--startas /bin/bash -- -c "exec $DAEMON $DAEMON_OPT >> /var/log/graylog-collector/console.log 2>&1" || return 2
sleep 2
log_end_msg $?
}
d_stop () {
log_daemon_msg "Stopping system $NAME Daemon"
start-stop-daemon --stop --retry 5 --quiet --user $DAEMON_USER
rm -f $PIDFILE
log_end_msg $?
}
case "$1" in
start|stop)
d_${1}
;;
restart|reload|force-reload)
d_stop
d_start
;;
force-stop)
d_stop
killall -q $NAME || true
sleep 2
killall -q -9 $NAME || true
;;
status)
status_of_proc "${PIDFILE}" "$DAEMON" "$NAME" && exit 0 || exit $?
;;
*)
echo "Usage: /etc/init.d/$NAME {start|stop|force-stop|restart|reload|force-reload|status}"
exit 1
;;
esac
exit 0
ありがとうございます。
アップデート1: 次の関数を生成し、醜いが動作するソリューション(少なくとも小さな要件については)でスクリプトを更新しました。
do_status () {
if { ps -U ${DAEMON_USER} ; } >/dev/null 2>&1 ; then
log_success_msg "${NAME} is running"
return 0
else
log_failure_msg "${NAME} is not running"
return $?
fi
}
その後、呼び出します。
status)
#status_of_proc "${PIDFILE}" "$DAEMON" "$NAME" && exit 0 || exit $?
do_status
;;
答え1
私の理解によると、「${PIDFILE}」と一緒に-pを使用する必要があります。つまり、「set -e」を使用しない限り、init.dスクリプトでプロセスを確認するために-pを使用しないでください。私の考えではうまくいかないようです。最後に、次のことを試してください。
status)
status_of_proc "$DAEMON" "$NAME" && exit 0 || exit $?
;;