Я написал долгую программу. Чтобы убедиться, что он работает на моем сервере, я последовал инструкции этого сайта для создания сервиса. В частности, подход «Debian и Ubuntu (sysvinit)» с использованием их файла примера, который входит в /etc/init.d/
.
Файл примера содержит следующее (я обновил переменные вверху, чтобы они соответствовали моему сценарию):
#!/bin/sh
### BEGIN INIT INFO
# Provides: exampledaemon
# Required-Start: $local_fs $network $syslog
# Required-Stop: $local_fs $network $syslog
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Example
# Description: Example start-stop-daemon - Debian
### END INIT INFO
NAME="my-service"
PATH="/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin"
APPDIR="/home/svc-user"
APPBIN="/home/svc-user/my-binary"
APPARGS=""
USER="svc-user"
GROUP="svc-user"
# Include functions
set -e
. /lib/lsb/init-functions
start() {
printf "Starting '$NAME'... "
start-stop-daemon --start --chuid "$USER:$GROUP" --background --make-pidfile --pidfile /var/run/$NAME.pid --chdir "$APPDIR" --exec "$APPBIN" -- $APPARGS || true
printf "done\n"
}
#We need this function to ensure the whole process tree will be killed
killtree() {
local _pid=$1
local _sig=${2-TERM}
for _child in $(ps -o pid --no-headers --ppid ${_pid}); do
killtree ${_child} ${_sig}
done
kill -${_sig} ${_pid}
}
stop() {
printf "Stopping '$NAME'... "
[ -z `cat /var/run/$NAME.pid 2>/dev/null` ] || \
while test -d /proc/$(cat /var/run/$NAME.pid); do
killtree $(cat /var/run/$NAME.pid) 15
sleep 0.5
done
[ -z `cat /var/run/$NAME.pid 2>/dev/null` ] || rm /var/run/$NAME.pid
printf "done\n"
}
status() {
status_of_proc -p /var/run/$NAME.pid "" $NAME && exit 0 || exit $?
}
case "$1" in
start)
start
;;
stop)
stop
;;
restart)
stop
start
;;
status)
status
;;
*)
echo "Usage: $NAME {start|stop|restart|status}" >&2
exit 1
;;
esac
exit 0
Я выполнил остальные шаги с сайта и запустил службу. top
показывает, что он работает и использует ожидаемое количество ресурсов. Когда я бегу service my-service status
Я вижу результат, созданный загруженным скриптом, но ничего не вижу в моем двоичном файле. Я новичок в администрировании серверов Linux, поэтому я не знаком с тем, что именно здесь происходит. Страница руководства для start-stop-daemon
ничего не упоминает о журналах.
Я мог бы (и, вероятно, буду) обновить свою службу, чтобы записывать журналы в файл вместо стандартного вывода, но я не хочу упускать эту возможность обучения.
Что происходит со стандартным выводом моей службы, и если я могу, как я могу получить к нему доступ?