web-dev-qa-db-ja.com

Ubuntuでのnodejs + foreverのシンプルな起動スクリプト

Ubuntu Sever12.04を使用しています。私は次のように実行したいnodejsアプリケーションを持っています:

NODE_ENV=production PORT=3001 APP_PATH=/var/www/myapp forever -a -l /var/www/myapp/forever.log -o /var/www/myapp/out.log -e /var/www/myapp/err.log /var/www/myapp/app.js

システムの起動時に実行し、システムのシャットダウン時に「永久に停止」したいと思います。そのための好ましい方法は、upstartスクリプトを使用することであることを読みました。それが私が試したことです:

description "Upstart script"

start on startup
stop on shutdown

expect fork

env MYAPP_PATH="/var/www/myapp"

script

    NODE_ENV=production PORT=3001 APP_PATH=$MYAPP_PATH exec forever -a -l $MYAPP_PATH/forever.log -o $MYAPP_PATH/out.log -e $MYAPP_PATH/err.log  $MYAPP_PATH/app.js

end script

pre-stop script

    exec forever stop $MYAPP_PATH/app.js >> $LOG

end script

実行するとハングし、ジョブはすでに実行されていると表示されます(実際には実行されていない場合)。

これを適切に行う方法についてのアドバイスをいただければ幸いです。ありがとう!

4
Svilen
description "Upstart script"

start on filesystem and started networking

参考: 「起動時に開始」は使用しないでください

stop on shutdown

expect fork

# Let's make sure we always have the right directory
chdir /var/www/myapp

env MYAPP_PATH="/var/www/myapp"
env NODE_ENV=production
env PORT=3001
# Is there a reason you didn't do this?
env APP_PATH=$MYAPP_PATH

script
  # Shell trick to re-direct this script's STDOUT/STDERR
  exec 2>> forever.log 1>> forever.log
  # You forgot the 'start' command. Without it, it doesn't fork.
  exec forever start -a -l forever.log -o out.log -e err.log app.js
end script

pre-stop script
  # Shell trick to re-direct this script's STDOUT/STDERR
  exec 2>> forever.log 1>> forever.log
  exec forever stop app.js
end script
5