自定义 linux 守护程序不会停止使用 "service stop"
custom linux daemon won't stop using "service stop"
我在 ubuntu 14.04 上通过 init.d 脚本编写了一个自定义的 python 守护进程 运行 作为服务。启动服务工作正常,但是当我尝试执行 "service monitor stop" 时,守护进程没有终止。我正在使用 pyinotify 守护文件监视程序以进行更改。
在 init.d 脚本中:
PATH=/sbin:/usr/sbin:/bin:/usr/bin
DESC="Monitor files"
NAME=monitor
DAEMON=/usr/bin/python
DAEMON_ARGS="/home/user/python/monitor.py"
PIDFILE=/home/user/logs/monitor.pid
LOGFILE=/home/user/logs/monitor.log
SCRIPTNAME=/etc/init.d/$NAME
...
do_stop()
{
# Return
# 0 if daemon has been stopped
# 1 if daemon was already stopped
# 2 if daemon could not be stopped
# other if a failure occurred
start-stop-daemon --stop --quiet --retry=TERM/30/KILL/5 --pidfile $PIDFILE --name $NAME
RETVAL="$?"
# Many daemons don't delete their pidfiles when they exit.
rm -f $PIDFILE
return "$RETVAL"
echo "done"
}
...
case "" in
start)
[ "$VERBOSE" != no ] && log_daemon_msg "Starting $DESC" "$NAME"
do_start
case "$?" in
0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
esac
;;
stop)
[ "$VERBOSE" != no ] && log_daemon_msg "Stopping $DESC" "$NAME"
do_stop
case "$?" in
0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
esac
;;
...
为了确保守护进程正确处理 SIGERM,我可以手动 运行 它:
bash$ /usr/bin/python /home/user/python/monitor.py
bash$ kill -Term PID
守护进程成功处理 SIGTERM 并正确退出。
我似乎无法弄清楚为什么当我这样做时它不处理它"service monitor stop"。
检查进程 $NAME
是否正确,如交付给 start-stop-daemon --stop
命令。我刚刚遇到这个问题,因为我是 运行 的进程在分叉其守护进程时最终得到了不同的名称。尝试 运行 这个来查看进程命令名称:
ps -o comm= $(cat /home/user/logs/monitor.pid)
我打赌你的输出是这个(而不是 monitor
):
python
然后将停止命令更改为如下所示,用 python
代替 $NAME
:
start-stop-daemon --stop --quiet --retry=TERM/30/KILL/5 --pidfile $PIDFILE --name python
我在 ubuntu 14.04 上通过 init.d 脚本编写了一个自定义的 python 守护进程 运行 作为服务。启动服务工作正常,但是当我尝试执行 "service monitor stop" 时,守护进程没有终止。我正在使用 pyinotify 守护文件监视程序以进行更改。
在 init.d 脚本中:
PATH=/sbin:/usr/sbin:/bin:/usr/bin
DESC="Monitor files"
NAME=monitor
DAEMON=/usr/bin/python
DAEMON_ARGS="/home/user/python/monitor.py"
PIDFILE=/home/user/logs/monitor.pid
LOGFILE=/home/user/logs/monitor.log
SCRIPTNAME=/etc/init.d/$NAME
...
do_stop()
{
# Return
# 0 if daemon has been stopped
# 1 if daemon was already stopped
# 2 if daemon could not be stopped
# other if a failure occurred
start-stop-daemon --stop --quiet --retry=TERM/30/KILL/5 --pidfile $PIDFILE --name $NAME
RETVAL="$?"
# Many daemons don't delete their pidfiles when they exit.
rm -f $PIDFILE
return "$RETVAL"
echo "done"
}
...
case "" in
start)
[ "$VERBOSE" != no ] && log_daemon_msg "Starting $DESC" "$NAME"
do_start
case "$?" in
0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
esac
;;
stop)
[ "$VERBOSE" != no ] && log_daemon_msg "Stopping $DESC" "$NAME"
do_stop
case "$?" in
0|1) [ "$VERBOSE" != no ] && log_end_msg 0 ;;
2) [ "$VERBOSE" != no ] && log_end_msg 1 ;;
esac
;;
...
为了确保守护进程正确处理 SIGERM,我可以手动 运行 它:
bash$ /usr/bin/python /home/user/python/monitor.py
bash$ kill -Term PID
守护进程成功处理 SIGTERM 并正确退出。
我似乎无法弄清楚为什么当我这样做时它不处理它"service monitor stop"。
检查进程 $NAME
是否正确,如交付给 start-stop-daemon --stop
命令。我刚刚遇到这个问题,因为我是 运行 的进程在分叉其守护进程时最终得到了不同的名称。尝试 运行 这个来查看进程命令名称:
ps -o comm= $(cat /home/user/logs/monitor.pid)
我打赌你的输出是这个(而不是 monitor
):
python
然后将停止命令更改为如下所示,用 python
代替 $NAME
:
start-stop-daemon --stop --quiet --retry=TERM/30/KILL/5 --pidfile $PIDFILE --name python