次の要件を持つ upstart を使用して Java サービスを実行するための有効な upstart conf スクリプトを定義できません。
- 複数のフォルダーに多くのjarがあるため、フォルダーを使用してクラスパスを指定する必要があります
- によって発せられたシャットダウン信号を聞く必要があります
service myservicename stop
その答えに基づいて、シャットダウンフックリスナーを実装したので、終了信号を送信してアプリケーションが終了するのを待つためにupstartが必要です。
これが私のバグのあるupstartスクリプトです:
description "masa"
author "Muhammad Gelbana <m.glba@gmail.com>"
start on runlevel [2345]
stop on shutdown
kill timeout 120
script
LOGS_DIR=/home/mgelbana/services/RealServices/logs
IPK_DB=/home/mgelbana/services/RealServices/config/db-ipk.properties
PRO_DB=/home/mgelbana/services/RealServices/config/db-reporting-engine.properties
MAIN_CLASS=com.sger.masaTA
mkdir -p $LOGS_DIR
CLASSPATH="/home/mgelbana/services/RealServices/masa-RealService-TA.jar"
for i in /home/mgelbana/services/commons/*.jar; do
CLASSPATH="$CLASSPATH:$i"
done
for i in /home/mgelbana/services/RealServices/lib/*.jar; do
CLASSPATH="$CLASSPATH:$i"
done
echo '\n\n\n====================================================='
echo 'Service startup:\t'`date`
echo 'Main class:\t\t'`echo $MAIN_CLASS`
echo 'Logs directory:\t\t'`echo $LOGS_DIR`
echo 'masa database configuration:\t'`echo $IPK_DB`
echo 'Pro configuration file:\t'`echo $PRO_DB`
echo 'Starting engine...'
java -Dta.id=2 -DIPK_DB=$IPK_DB -DPRO_DB=$PRO_DB -cp $CLASSPATH $MAIN_CLASS
end script
次のエラーが/var/log/upstart/myservicename.log
ログ
に表示されます。/proc/self/fd/9: 9: /proc/self/fd/9: Syntax error: word unexpected (expecting "do")
ありがとうございました。