Управление котом с супервайзером

14

Есть ли способ «изящно» отключить Tomcat при управлении через супервизор?

Насколько я понимаю, сценарий Tomcat shutdown.sh взаимодействует с Tomcat на порту выключения, чтобы инициировать постепенное завершение работы. У Supervisor, похоже, нет способа задать «команду» выключения, только с помощью сигналов.

Кто-нибудь успешно использовал супервизор с Tomcat?

Кроме того, так как скрипт startup.sh tomcat запускает процесс java, я копирую полученную команду java непосредственно в supervisor, но это не так хорошо, как использование сценария startup.sh из-за всех настроек среды. Есть ли способ заставить супервизора использовать скрипт startup.sh, но все же отслеживать результирующий дочерний процесс Java?

отметка
источник

Ответы:

6

Спасибо Марку за ссылку на этот скрипт; Вот мой рабочий пример для CentOS:

#!/bin/bash
# Source: https://confluence.atlassian.com/plugins/viewsource/viewpagesrc.action?pageId=252348917
function shutdown()
{
    date
    echo "Shutting down Tomcat"
    unset CATALINA_PID # Necessary in some cases
    unset LD_LIBRARY_PATH # Necessary in some cases
    unset JAVA_OPTS # Necessary in some cases

    $TOMCAT_HOME/bin/catalina.sh stop
}

date
echo "Starting Tomcat"
export CATALINA_PID=/tmp/$$
export JAVA_HOME=/usr/local/java
export LD_LIBRARY_PATH=/usr/local/apr/lib
export JAVA_OPTS="-Dcom.sun.management.jmxremote.port=8999 -Dcom.sun.management.jmxremote.password.file=/etc/tomcat.jmx.pwd -Dcom.sun.management.jmxremote.access.file=/etc/tomcat.jmxremote.access -Dcom.sun.management.jmxremote.ssl=false -Xms128m -Xmx3072m -XX:MaxPermSize=256m"

# Uncomment to increase Tomcat's maximum heap allocation
# export JAVA_OPTS=-Xmx512M $JAVA_OPTS

. $TOMCAT_HOME/bin/catalina.sh start

# Allow any signal which would kill a process to stop Tomcat
trap shutdown HUP INT QUIT ABRT KILL ALRM TERM TSTP

echo "Waiting for `cat $CATALINA_PID`"
wait `cat $CATALINA_PID`

И вот что я использовал в /etc/supervisord.conf:

[program:tomcat]
directory=/usr/local/tomcat
command=/usr/local/tomcat/bin/supervisord_wrapper.sh
stdout_logfile=syslog
stderr_logfile=syslog
user=apache

Запуск, это выглядит так:

[root@qa1.qa:~]# supervisorctl start tomcat
tomcat: started
[root@qa1.qa:~]# supervisorctl status
tomcat                           RUNNING    pid 9611, uptime 0:00:03
[root@qa1.qa:~]# ps -ef|grep t[o]mcat
apache    9611  9581  0 13:09 ?        00:00:00 /bin/bash /usr/local/tomcat/bin/supervisord_wrapper.sh start
apache    9623  9611 99 13:09 ?        00:00:10 /usr/local/java/bin/java -Djava.util.logging.config.file=/usr/local/tomcat/conf/logging.properties -Dcom.sun.management.jmxremote.port=8999 -Dcom.sun.management.jmxremote.password.file=/etc/tomcat.jmx.pwd -Dcom.sun.management.jmxremote.access.file=/etc/tomcat.jmxremote.access -Dcom.sun.management.jmxremote.ssl=false -Xms128m -Xmx3072m -XX:MaxPermSize=256m -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.endorsed.dirs=/usr/local/tomcat/endorsed -classpath /usr/local/tomcat/bin/bootstrap.jar -Dcatalina.base=/usr/local/tomcat -Dcatalina.home=/usr/local/tomcat -Djava.io.tmpdir=/usr/local/tomcat/temp org.apache.catalina.startup.Bootstrap start

Сначала я попытался добавить эти переменные окружения в /etc/supervisord.conf через environmentдирективу, но столкнулся с проблемой с JAVA_OPTS, со всеми пробелами и знаками равенства. Поместив его в скрипт-обертку, позаботился об этом.

Надеюсь, это поможет сэкономить кому-то еще время!

Аарон Р.
источник
1
Я могу подтвердить, что это работает с Tomcat 7 в supervisord v3.0 на CentOS 6. Обратите внимание, что startв конце команды в /etc/supervisord.conf есть ненужный аргумент, так как скрипт ничего не делает с ним.
Рик Хэнлон II
Ха, спасибо за улов! Я имел обыкновение передавать это вместе с catalina.sh. Я удалил это.
Аарон Р.
20

В catalina.sh есть команда «выполнить». Он отлично работает с супервизором:

[program:tomcat]
command=/path/to/tomcat/bin/catalina.sh run
process_name=%(program_name)s
startsecs=5
stopsignal=INT
user=tomcat
redirect_stderr=true
stdout_logfile=/var/log/tomcat.log

Запуск кота под именем catalina.sh run работает на переднем плане, имеет правильный pid и принимает сигналы. Прекрасно работает с супервизором.

Сергей Козлов
источник
1
Это должен быть принятый ответ.
МаратC
Я получаю сообщение «Невозможно запустить сервер. Экземпляр сервера не настроен»
xtian
0

У Supervisor, похоже, нет способа задать «команду» выключения, только с помощью сигналов.

Вы пытались использовать stopsignal=QUIT?

[program:tomcat]
command=java ...
process_name=tomcat
priority=150
startsecs=10
directory=./
stopsignal=QUIT
stdout_logfile=./logs/tomcat.log
stderr_logfile=./logs/tomcat.err
кванты
источник
похоже, что QUIT заставляет tomcat сделать дамп потока в журнал catalina.out (он же консоль).
Mark
1
Это интересное предложение: confluence.atlassian.com/plugins/viewsource/... - По существу обернуть catalina.sh в сценарии и установить функцию ловушки для выключения ...
Mark
@ Марк это для запуска на OSX, как его можно адаптировать для супервизора?
Conrad.Dean
1
@ Conrad.Dean руководитель использует те же предположения. Тот же сценарий работает для супервизора без изменений
Mark