Скрипт инициализации не работает при загрузке - в противном случае работает нормально

Я написал здесь демона Python, основанного на методе двойной вилки.

Отлично работает при звонке scsdaemon.py Непосредственное использование аргументов start|stop, и приведенный ниже скрипт init также работает при вызове, когда raspberry уже загружен.

Я убедился, что скрипт вызывается во время загрузки, запустив sudo update-rc.d scsdaemon defaults а также убедился, что это исполняемый файл:

$ ls -l /etc/init.d/scsdaemon
-rwxr-xr-x 1 root root 1639 Mar 14 19:25 /etc/init.d/scsdaemon

Я уже положил эхо-заявление, которое перенаправляется в файл в /tmp в сценарий инициализации и, следовательно, может проверить, что сценарий запущен.
Но служба не запускается. В журнале нет ни одного сообщения, а также журнал, который создает мое приложение, но пустой.

Что мне не хватает? Почему это работает во время нормальной работы, а не во время загрузки?

#!/bin/sh

### BEGIN INIT INFO
# Provides:          scsdaemon
# Required-Start:    $remote_fs $syslog $network
# Required-Stop:     $remote_fs $syslog $network
# Default-Start:     2 3 4 5
# Default-Stop:      0 1 6
# Short-Description: Put a short description of the service here
# Description:       Put a long description of the service here
### END INIT INFO

# Change the next 3 lines to suit where you install your script and what you want to call it
DIR=/var/www/bin/py
DAEMON=$DIR/scsdaemon.py
DAEMON_NAME=scsdaemon

# Add any command line options for your daemon here
DAEMON_OPTS=""

# This next line determines what user the script runs as.
# Root generally not recommended but necessary if you are using the Raspberry Pi GPIO from Python.
DAEMON_USER=www-data

# The process ID of the script when it runs is stored here:
PIDFILE=/tmp/$DAEMON_NAME.pid

. /lib/lsb/init-functions

do_start () {
    log_daemon_msg "Starting system $DAEMON_NAME daemon"
    start-stop-daemon --start --user $DAEMON_USER --chuid $DAEMON_USER --exec $DAEMON -- start $DAEMON_OPTS
    log_end_msg $?
}
do_stop () {
    log_daemon_msg "Stopping system $DAEMON_NAME daemon"
    start-stop-daemon --start --exec $DAEMON --retry 10 -- stop $DAEMON_OPTS
    log_end_msg $?
}

case "$1" in

    start|stop)
        do_${1}
        ;;

    restart|reload|force-reload)
        do_stop
        do_start
        ;;

    status)
        status_of_proc "$DAEMON_NAME" "$DAEMON" && exit 0 || exit $?
        ;;

    *)
        echo "Usage: /etc/init.d/$DAEMON_NAME {start|stop|restart|status}"
        exit 1
        ;;

esac
exit 0

0 ответов

Другие вопросы по тегам