1

У меня проблема с уничтожением моей Java-программы в Ubuntu. Я создал следующий скрипт инициализации:

#!/bin/sh

### BEGIN INIT INFO
# Provides:          control ...
# Required-Start:    $remote_fs $network $syslog
# Required-Stop:     $remote_fs $network $syslog
# Default-Start:     2 3 4 5
# Default-Stop:      0 1 6
# Short-Description: ...
# Description:       ...
### END INIT INFO

DAEMON_PATH="/mnt/Data/wstlm"
DAEMON=startWstlm
DAEMONOPTS=""

NAME=wstlm
DESC="My daemon description"
PIDFILE=/var/run/$NAME.pid
SCRIPTNAME=/etc/init.d/$NAME

case "$1" in
start)
        printf "%-50s" "Starting $NAME..."
        cd $DAEMON_PATH
        PID=`./$DAEMON $DAEMONOPTS > /dev/null 2>&1 & echo $!`
        echo "Saving PID" $PID " to " $PIDFILE
        if [ -z $PID ]; then
            printf "%s\n" "Fail"
        else
            echo $PID > $PIDFILE
            printf "%s\n" "Ok"
        fi
;;
status)
        printf "%-50s" "Checking $NAME..."
        if [ -f $PIDFILE ]; then
            PID=`cat $PIDFILE`
            if [ -z "`ps axf | grep ${PID} | grep -v grep`" ]; then
                printf "%s\n" "Process dead but pidfile exists"
            else
                echo "Running"
            fi
        else
            printf "%s\n" "Service not running"
        fi
;;
stop)
        printf "%-50s" "Stopping $NAME"
            PID=`cat $PIDFILE`
            cd $DAEMON_PATH
        if [ -f $PIDFILE ]; then
            kill -9 $PID
            printf "%s\n" "Ok"
            rm -f $PIDFILE
        else
            printf "%s\n" "pidfile not found"
        fi
;;

restart)
    $0 stop
    $0 start
;;

*)
        echo "Usage: $0 {status|start|stop|restart}"
        exit 1
esac

Этот скрипт инициализации меняет каталог на мою программу, а содержимое исполняемого файла startWstlm:

#!/ Бен / ш
дата эха date +"%Y/%m/%d %T" - запуск WSTLm 1 >> / mnt / Data / wstlm / wstlm.log
java -Djavax.net.ssl.trustStore = jssecacerts -jar /mnt/Data/wstlm/myProgram.jar

Я добавил сценарий инициализации в файл init.d. Если я позвоню

sudo service myProgram start

Программа запускается правильно. Но если я использую

sudo service myProgram stop

Программа не закрывается. Только команда bash, которая запустила мою java-программу, уничтожается.

Перед выполнением остановки:

1 root /bin /sh ./startWstlm
2 root java -Djavax.net.ssl.trustStore = jssecacerts -jar /mnt/Data/wstlm/myProgram.jar
3 root java -Djavax.net.ssl.trustStore = jssecacerts -jar /mnt/Data/wstlm/myProgram.jar
4 root java -Djavax.net.ssl.trustStore = jssecacerts -jar /mnt/Data/wstlm/myProgram.jar

После выполнения остановки:

(обратите внимание, этот удар был убит)
2 root java -Djavax.net.ssl.trustStore = jssecacerts -jar /mnt/Data/wstlm/myProgram.jar
3 root java -Djavax.net.ssl.trustStore = jssecacerts -jar /mnt/Data/wstlm/myProgram.jar
4 root java -Djavax.net.ssl.trustStore = jssecacerts -jar /mnt/Data/wstlm/myProgram.jar

(Кстати: почему есть несколько процессов этой банки?)

Так что проблема в том, что я не могу остановить свою программу. Что отчасти .. раздражает. У кого-нибудь есть идея?

1 ответ1

0

Во-первых, не используйте kill -9 ; простого kill должно быть достаточно. Во-вторых, посмотрите эту страницу для хорошего объяснения того, как убить дочерние процессы, когда родительский элемент должен выйти. В этом случае startWstim должен позаботиться о том, чтобы убить Java-программу до ее завершения.

Наконец, может быть проще обойтись без startWstim и вместо этого выполнить команды, содержащиеся в нем непосредственно в вашем скрипте инициализации:

start)
    printf "%-50s" "Starting $NAME..."
    cd $DAEMON_PATH
    echo "$(date +"%Y/%m/%d %T") - start WSTLm" >> /mnt/Data/wstlm/wstlm.log
    java -Djavax.net.ssl.trustStore=jssecacerts -jar /mnt/Data/wstlm/myProgram.jar &
    PID=$!

Обратите внимание, что вам не нужна подоболочка для получения идентификатора процесса Java-программы, и вам нужно захватить выходные данные команды date , чтобы вывести ее в файл журнала.

Всё ещё ищете ответ? Посмотрите другие вопросы с метками .