Спасибо много. Этот совет о «не ожидайте строфа» является золотым. К сожалению, выскочка сохраняет некоторое состояние между перезапусками и иногда зависает с нужным файлом без причины. Делает отладку очень сложно.
Я пытаюсь запустить скрипт 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»?