init.d 스크립트에서 시작할 때 kill -s SIGINT가 예상대로 작동하지 않습니다.

init.d 스크립트에서 시작할 때 kill -s SIGINT가 예상대로 작동하지 않습니다.

부팅 시(venv 사용) 일부 Python 스크립트를 시작하고 문제가 발생하면 자동으로 다시 시작할 수 있도록 상태를 모니터링하고 싶습니다.

prg.py나는 다음을 만들었습니다: - 영원히 잠들고 sigint 신호에 따라 종료되는 간단한 Python 예제입니다 .

  • prg.sh모니터링을 위한 bash 스크립트 prg.py. 프로세스가 중지되면 스크립트가 프로그램을 다시 시작합니다. 스크립트가 sigint를 받으면 prg.pysigint를 프로그램에 보내고 종료됩니다.

  • bash script() 를 시작하는 데 사용되는 Script() init.d. 코드는 내 것이 아닙니다. GitHub에서 찾아서 수정했습니다. 링크를 검색 중인데 찾으면 글 수정하겠습니다.prgprg.shprg

prg.py:

import signal
import time

def signal_handler(sig, frame):
  print('sigint')
  quit(0)

signal.signal(signal.SIGINT, signal_handler)
print ('aaa')
while (1):
  time.sleep(1.5)

prg.sh:

#!/bin/bash

#set -x

DIR="/home/pi"
PRESCRIPT="source venv/bin/activate;python --version"
SCRIPT="python prg.py"

EXITDO=0
PID=-1
trap ctrl_c INT
function ctrl_c() {
  echo 'SIGINT intercepted.'
  EXITDO=1
}

#Main loop
while [ $EXITDO -eq 0 ]; do
  echo 'Starting process…'
  cd "$DIR"
  eval $PRESCRIPT
  $SCRIPT &
  PID=$(echo $!)
  echo "Process started with PID: $PID"
  while $(kill -0 $PID) && [ $EXITDO -eq 0 ]; do
    sleep 1
  done
  if [ $EXITDO -eq 0 ]; then
    echo 'Process terminated. Restart.'
  else
    echo 'Kill service.'
    kill -2 $PID
  fi
done

prg:

#!/bin/sh
### BEGIN INIT INFO
# Provides:          prg
# Required-Start:    $local_fs $network $named $time $syslog
# Required-Stop:     $local_fs $network $named $time $syslog
# Default-Start:     2 3 4 5
# Default-Stop:      0 1 6
# Description:       <DESCRIPTION>
### END INIT INFO
NAME=prg
SCRIPT="/home/pi/prg.sh"

PIDFILE=/var/run/$NAME.pid

start() {
  if [ -f $PIDFILE ] && [ -s $PIDFILE ] && kill -0 $(cat $PIDFILE); then
    echo 'Service already running' >&2
    return 1
  fi
  echo 'Starting service…' >&2
  #local CMD="$SCRIPT &> \"$LOGFILE\" & echo \$!"
  #su -c "$CMD" $RUNAS > "$PIDFILE"
  # Try with this command line instead of above if not workable
  # su -s /bin/sh $RUNAS -c "$CMD" > "$PIDFILE"
  $SCRIPT &
  echo $! > "$PIDFILE"
  PID=$(cat $PIDFILE)
  if kill -0 $(cat $PIDFILE) > /dev/null
  then
    echo "$NAME is now running, the PID is $PID"
  else
    echo ''
    echo "Error! Could not start $NAME!"
  fi
}

stop() {
  if [ ! -f "$PIDFILE" ] || ! kill -0 $(cat "$PIDFILE"); then
    echo 'Service not running' >&2
    return 1
  fi
  echo 'Stopping service…' >&2
  #Kill by pid
  kill -2 $(cat "$PIDFILE")
  #remove .pid file
  sleep 3
  if ! kill -0 $(cat "$PIDFILE"); then
    rm -f "$PIDFILE"
    echo 'Service stopped' >&2
  fi
}

uninstall() {
  echo -n "Are you really sure you want to uninstall this service? That cannot be undone. [yes|No] "
  local SURE
  read SURE
  if [ "$SURE" = "yes" ]; then
    stop
    rm -f "$PIDFILE"
    echo "Notice: log file was not removed: $LOGFILE" >&2
    update-rc.d -f $NAME remove
    rm -fv "$0"
  else
    echo "Abort!"
  fi
}

status() {
    printf "%-50s" "Checking $NAME..."
    if [ -f $PIDFILE ] && [ -s $PIDFILE ]; then
        PID=$(cat $PIDFILE)
            if [ -z "$(ps axf | grep ${PID} | grep -v grep)" ]; then
                printf "%s\n" "The process appears to be dead but pidfile still exists"
            else
                echo "Running, the PID is $PID"
            fi
    else
        printf "%s\n" "Service not running"
    fi
}


case "$1" in
  start)
    start
    ;;
  stop)
    stop
    ;;
  status)
    status
    ;;
  uninstall)
    uninstall
    ;;
  restart)
    stop
    start
    ;;
  *)
    echo "Usage: $0 {start|stop|status|restart|uninstall}"
esac
  • prg.sh프로그램을 시작하면 예상대로 실행됩니다.

  • 자동으로 종료 prg.py하고 다시 시작할 수 있습니다 .prg.shprg.py

  • sigint를 보내고 중지 하고 닫을 수 있습니다 prg.sh.prg.shprg.py

  • prg명령 으로 시작하면 sudo service prg start모든 것이 잘 작동합니다.

하지만

  • sigint이 경우 을( 를) 보내면 prg.sh아무 일도 일어나지 않습니다..

  • 간단히 말해서 service prg stop작동하지 않으며 그 이유를 이해하지 못합니다.

미리 감사드립니다.

관련 정보