Запуск приложения Java как службы в Linux
Я написал серверное приложение Java, которое работает на стандартном виртуальном размещенном решении Linux. Приложение работает все время прослушивания сокетов соединений и создания новых обработчиков для них. Это реализация на стороне сервера для клиент-серверного приложения.
Как я начинаю это, включив его в start up rc.местные скрипт сервера. Однако после запуска я не знаю, как получить к нему доступ, чтобы остановить его, и если я хочу установить обновление, поэтому я должен перезапустить сервер, чтобы перезапустить приложение.
на ПК с windows для этого типа приложений я мог бы создать службу windows, а затем я могу остановить и запустить ее, как я хочу. Есть ли что-то подобное в Linux box, чтобы при запуске этого приложения я мог остановить его и перезапустить без полного перезапуска сервера.
мое приложение называется WebServer.исполняемый. Он запускается при запуске сервера, включая его в мой rc.местные такие как:
java -jar /var/www/vhosts/myweb.com/phpserv/WebServer.jar &
Я немного нуб в Linux, поэтому любой пример будет оценен с любыми сообщениями. Однако у меня есть SSH и полный FTP-доступ к коробке для установки любых обновлений, а также доступ к панели Plesk.
14 ответов
Я написал здесь еще одну простую обертку:
#!/bin/sh
SERVICE_NAME=MyService
PATH_TO_JAR=/usr/local/MyProject/MyJar.jar
PID_PATH_NAME=/tmp/MyService-pid
case in
start)
echo "Starting $SERVICE_NAME ..."
if [ ! -f $PID_PATH_NAME ]; then
nohup java -jar $PATH_TO_JAR /tmp 2>> /dev/null >> /dev/null &
echo $! > $PID_PATH_NAME
echo "$SERVICE_NAME started ..."
else
echo "$SERVICE_NAME is already running ..."
fi
;;
stop)
if [ -f $PID_PATH_NAME ]; then
PID=$(cat $PID_PATH_NAME);
echo "$SERVICE_NAME stoping ..."
kill $PID;
echo "$SERVICE_NAME stopped ..."
rm $PID_PATH_NAME
else
echo "$SERVICE_NAME is not running ..."
fi
;;
restart)
if [ -f $PID_PATH_NAME ]; then
PID=$(cat $PID_PATH_NAME);
echo "$SERVICE_NAME stopping ...";
kill $PID;
echo "$SERVICE_NAME stopped ...";
rm $PID_PATH_NAME
echo "$SERVICE_NAME starting ..."
nohup java -jar $PATH_TO_JAR /tmp 2>> /dev/null >> /dev/null &
echo $! > $PID_PATH_NAME
echo "$SERVICE_NAME started ..."
else
echo "$SERVICE_NAME is not running ..."
fi
;;
esac
вы можете следовать полный учебник для init.d здесь и для systemd (ubuntu 16+) здесь
Если вам нужен журнал вывода, замените 2
nohup java -jar $PATH_TO_JAR /tmp 2>> /dev/null >> /dev/null &
линии
nohup java -jar $PATH_TO_JAR >> myService.out 2>&1&
простым решением является создание скрипта start.sh это запускает Java через nohup, а затем сохраняет PID в файл:
nohup java -jar myapplication.jar > log.txt 2> errors.txt < /dev/null &
PID=$!
echo $PID > pid.txt
тогда ваш сценарий остановки stop.sh прочитал бы PID из файла и убил бы приложение:
PID=$(cat pid.txt)
kill $PID
конечно, я опустил некоторые детали, например, проверить, существует ли процесс и удалить pid.txt
Если вы закончили.
скрипт инициализации службы Linux хранятся в /etc/init.d
. Вы можете копировать и настраивать /etc/init.d/skeleton
файл, а затем вызов
service [yourservice] start|stop|restart
см.http://www.ralfebert.de/blog/java/debian_daemon/. Его для Debian (так, Ubuntu также), но подходит больше дистрибутива.
возможно, не лучшее решение для dev-ops, но хорошо для общего использования сервера для вечеринки lan или аналогичного.
использовать screen
для запуска сервера, а затем отсоединить перед выходом из системы, это будет держать процесс работает, вы можете повторно подключить в любой момент.
документооборот:
пуск экран: screen
запустить сервер: java -jar minecraft-server.jar
отключить нажатием: Ctl-a
, d
прикрепления: screen -r
подробнее здесь: https://www.gnu.org/software/screen/manual/screen.html
Другой альтернативой, которая также довольно популярна, является Java Service Wrapper. Это также довольно популярно в сообществе OSS.
ссыль приложение Spring Boot в качестве службы а также, я бы пошел на systemd
версия, так как это самый простой, наименее подробный и лучше всего интегрирован в современные дистрибутивы (и даже не очень современные, такие как CentOS 7.икс.)
вот пример сценария оболочки (убедитесь, что вы заменили математическое имя на имя вашего приложения):
#!/bin/bash
### BEGIN INIT INFO
# Provides: MATH
# Required-Start: $java
# Required-Stop: $java
# Short-Description: Start and stop MATH service.
# Description: -
# Date-Creation: -
# Date-Last-Modification: -
# Author: -
### END INIT INFO
# Variables
PGREP=/usr/bin/pgrep
JAVA=/usr/bin/java
ZERO=0
# Start the MATH
start() {
echo "Starting MATH..."
#Verify if the service is running
$PGREP -f MATH > /dev/null
VERIFIER=$?
if [ $ZERO = $VERIFIER ]
then
echo "The service is already running"
else
#Run the jar file MATH service
$JAVA -jar /opt/MATH/MATH.jar > /dev/null 2>&1 &
#sleep time before the service verification
sleep 10
#Verify if the service is running
$PGREP -f MATH > /dev/null
VERIFIER=$?
if [ $ZERO = $VERIFIER ]
then
echo "Service was successfully started"
else
echo "Failed to start service"
fi
fi
echo
}
# Stop the MATH
stop() {
echo "Stopping MATH..."
#Verify if the service is running
$PGREP -f MATH > /dev/null
VERIFIER=$?
if [ $ZERO = $VERIFIER ]
then
#Kill the pid of java with the service name
kill -9 $($PGREP -f MATH)
#Sleep time before the service verification
sleep 10
#Verify if the service is running
$PGREP -f MATH > /dev/null
VERIFIER=$?
if [ $ZERO = $VERIFIER ]
then
echo "Failed to stop service"
else
echo "Service was successfully stopped"
fi
else
echo "The service is already stopped"
fi
echo
}
# Verify the status of MATH
status() {
echo "Checking status of MATH..."
#Verify if the service is running
$PGREP -f MATH > /dev/null
VERIFIER=$?
if [ $ZERO = $VERIFIER ]
then
echo "Service is running"
else
echo "Service is stopped"
fi
echo
}
# Main logic
case "" in
start)
start
;;
stop)
stop
;;
status)
status
;;
restart|reload)
stop
start
;;
*)
echo $"Usage: {start|stop|status|restart|reload}"
exit 1
esac
exit 0
С приложение Spring Boot в качестве службы, Я могу порекомендовать Python-based supervisord
приложение. См. этот вопрос переполнения стека для получения дополнительной информации. Это очень просто настроить.
самый простой способ-это использовать supervisord
. Смотрите ЗДЕСЬ Полную информацию: http://supervisord.org/
Подробнее:
можно использовать бережливость сервера или JMX для связи с вашим сервисом Java.
другие ответы делают хорошую работу, давая пользовательские скрипты и настройки в зависимости от вашей платформы. В дополнение к этим, вот зрелые, специальные целевые программы, о которых я знаю:
- JSW от TanukiSoftware
- YAJSW - это открытый клон источника свыше. Он написан на Java, и это процесс няни, который управляет дочерним процессом (вашим кодом) в соответствии с конфигурациями. Работает на windows / linux.
- JSVC родное приложение. Это также процесс няни, но он вызывает ваше дочернее приложение через JNI, а не как подпроцесс.
для запуска Java-кода в качестве демона (службы) вы можете написать заглушку на основе JNI.
http://jnicookbook.owsiak.org/recipe-no-022/
для примера кода, основанного на JNI. В этом случае вы демонизируете код, который был запущен как Java, и main loop выполняется в C. Но также можно поместить main, daemon's, service loop внутри Java.
https://github.com/mkowsiak/jnicookbook/tree/master/recipeNo029
есть весело с JNI!
однако после запуска я не знаю, как получить к нему доступ, чтобы остановить его
вы можете написать простой скрипт остановки, который greps для вашего процесса java, извлекает PID и вызывает kill на нем. Это не вычурно, но прямолинейно. Что-то вроде этого может помочь в начале:
#!/bin/bash
PID = ps ax | grep "name of your app" | cut -d ' ' -f 1
kill $PID
С Справочник По Весенней Загрузке
установка как init.D сервис (система V)
просто symlink банку
init.d
поддержка стандартаstart
,stop
,restart
иstatus
команды. Предполагая, что у вас есть приложение Spring Boot, установленное в /var / myapp, чтобы установить приложение Spring Boot в качестве init.D сервис просто создает символическую ссылку:$ sudo ln -s /var/myapp/myapp.jar /etc/init.d/myapp
после установки, вы можете запустить и остановить службу обычным способом. Например, в системе на основе Debian:
$ service myapp start
если приложение не запускается, проверьте файл журнала записывается
/var/log/<appname>.log
для ошибок.
Читать далее чтобы знать, как защитить развернутой службы.
после того, как я написал, я обнаружил, что моя служба не запускается с этим сообщением об ошибке в журналах:старт-стоп-демона: непризнанный вариант --no-close. И мне удалось исправить это, создав файл конфигурации /var/myapp/myapp.conf
следующего содержания
USE_START_STOP_DAEMON=false