本番環境で node.js スクリプト (Balloons.IO) をセットアップしようとしています。永久にインストールしましたが、サーバーの再起動forever list
コマンドが返さinfo: No forever processes running
れるたびに この他の問題を修正するには、IPTABLES コマンドを実行してポート 9090 への着信接続を受け入れる必要があり、IPTABLES はサーバーが再起動するまでこの構成を保持します...要するに、node.js スクリプトを起動して実行し続けるためだけに多くの問題が発生します。 .
これらすべてを修正するために、次のコマンドを crontab に追加しました。
* * * * * /home/steph/scripts/script-check.sh >> /home/steph/scripts/startup.log
cron ジョブが起動されますが、startup.log に以下の出力が含まれている理由はわかりますか?
Mon Mar 4 20:04:01 EST 2013
REDIS: [OFFLINE] Starting Redis Server...[FAILED]
BALLOONS.IO: [OFFLINE] Starting Balloons.IO (with Forever)...[FAILED]
FIREWALL (port 9090): [DENIED] Enabling port 9090...
[FAILED]
script-check.sh Linux を手動で実行すると、次のように生成されます。
Mon Mar 4 20:06:38 EST 2013
REDIS: [ONLINE]
BALLOONS.IO: [OFFLINE] Starting Balloons.IO (with Forever)...[SUCCESS]
FIREWALL (port 9090): [ACCEPT]
script-check.sh
内容は次のとおりです。
echo -ne "$(date)\n";
echo -ne "REDIS: ";
if [ "`redis-cli ping | grep -i pong`" ]
then
echo -ne "[ONLINE]\n";
else
echo -ne "[OFFLINE] Starting Redis Server...";
echo -ne `/etc/init.d/redis_6379 start > /home/steph/stat_redis.log`;
if [ "`redis-cli ping | grep -i pong`" ]
then
echo -ne "[SUCCESS]\n";
else
echo -ne "[FAILED]\n";
fi
fi
echo -ne "BALLOONS.IO: ";
if [ "`forever list | grep -i balloons`" ]
then
echo -ne "[ONLINE]\n";
else
echo -ne "[OFFLINE] Starting Balloons.IO (with Forever)...";
echo -ne `forever start /home/steph/Balloons.IO/balloons.js > /home/steph/stat_balloons.log`;
if [ "`forever list | grep -i balloons`" ]
then
echo -ne "[SUCCESS]\n";
else
echo -ne "[FAILED]\n";
fi
fi
echo -ne "FIREWALL (port 9090): ";
if [ "`iptables-save | grep -- "-A INPUT -p tcp -m tcp --dport 9090 -j ACCEPT"`" ]
then
echo -ne "[ACCEPT]\n";
else
echo -ne "[DENIED] Enabling port 9090...";
echo `iptables -A INPUT -p tcp -m tcp --dport 9090 -j ACCEPT > /home/steph/stat_iptables.log`
if [ "`iptables-save | grep -- "-A INPUT -p tcp -m tcp --dport 9090 -j ACCEPT"`" ]
then
echo -ne "[SUCCESS]\n";
else
echo -ne "[FAILED]\n";
fi
fi