Спасибо много. Этот совет о «не ожидайте строфа» является золотым. К сожалению, выскочка сохраняет некоторое состояние между перезапусками и иногда зависает с нужным файлом без причины. Делает отладку очень сложно.

Я пытаюсь запустить скрипт Python как сервис (демон) в (Ubuntu) Linux.

В Интернете существует несколько решений, таких как:

http://pypi.python.org/pypi/python-daemon/

Хорошо управляемый процесс демона Unix сложно сделать правильно, но необходимые шаги практически одинаковы для каждой программы демона. Экземпляр DaemonContext содержит поведение и настроенную среду процесса для программы; используйте экземпляр как менеджер контекста, чтобы войти в состояние демона.

http://www.jejik.com/articles/2007/02/a_simple_unix_linux_daemon_in_python/

Однако, поскольку я хочу интегрировать свой скрипт на Python специально с Ubuntu Linux, мое решение представляет собой комбинацию со скриптом init.d

#!/bin/bash

WORK_DIR="/var/lib/foo"
DAEMON="/usr/bin/python"
ARGS="/opt/foo/linux_service.py"
PIDFILE="/var/run/foo.pid"
USER="foo"

case "$1" in
  start)
    echo "Starting server"
    mkdir -p "$WORK_DIR"
    /sbin/start-stop-daemon --start --pidfile $PIDFILE \
        --user $USER --group $USER \
        -b --make-pidfile \
        --chuid $USER \
        --exec $DAEMON $ARGS
    ;;
  stop)
    echo "Stopping server"
    /sbin/start-stop-daemon --stop --pidfile $PIDFILE --verbose
    ;;
  *)
    echo "Usage: /etc/init.d/$USER {start|stop}"
    exit 1
    ;;
esac

exit 0

и в питоне:

import signal
import time
import multiprocessing

stop_event = multiprocessing.Event()

def stop(signum, frame):
    stop_event.set()

signal.signal(signal.SIGTERM, stop)

if __name__ == '__main__':
    while not stop_event.is_set():
        time.sleep(3)

Мой вопрос сейчас заключается в том, является ли этот подход правильным. Нужно ли обрабатывать какие-либо дополнительные сигналы? Будет ли это «хорошо управляемый процесс демона Unix»?

Ответы на вопрос(2)

Ваш ответ на вопрос