Bir tmux oturumu içinde bir daemon başlatmak için bir uptart komut dosyası yazdım. İyi çalışıyor ve beklenmedik bir şekilde ölürse süreci yeniden doğurur, ancak manuel olarak durduramıyorum.
Bukkit denilen iş şöyle görünür:
start on filesystem
stop on runlevel [!2345]
respawn
respawn limit 5 30
chdir /home/minecraft/bukkit
expect daemon
kill timeout 30
pre-start script
test -x /home/minecraft/bukkit/craftbukkit-0.0.1-SNAPSHOT.jar || { stop; exit 0; }
end script
pre-stop script
tmux send -t bukkit "stop"
tmux send -t bukkit "Enter"
sleep 10 # Wait for server to shut down properly
end script
exec tmux new-session -d -s minecraft -n bukkit "sudo -u minecraft -- /home/minecraft/java/jre1.6.0_27/bin/java -Xincgc -Xmx1G -jar /home/minecraft/bukkit/craftbukkit-0.0.1-SNAPSHOT.jar"
Bir sorun stop bukkit
çıkardığımda ~ 10 saniye (uyku zamanlayıcısı, sanırım) donuyor ve yazdırılıyor bukkit start/running, process 2391
. Uptart'ı hata ayıklamak için ayarladığımda, günlükte şu ilgili satırları buldum:
Sep 21 19:14:59 cheftest init: bukkit goal changed from start to stop
Sep 21 19:14:59 cheftest init: bukkit main process (2499) exited normally
Sep 21 19:14:59 cheftest init: bukkit main process ended, respawning
Sep 21 19:14:59 cheftest init: bukkit goal changed from stop to respawn
Upstart, işlemi durdurması gerektiğinde neden yeniden doğmaya devam ediyor?