为什么在作为守护进程运行的node.js脚本中执行子进程后没有设置stdout?

时间:2013-05-04 17:41:44

标签: node.js bash daemon

如果我从命令行运行它(node index.js),这可以正常工作。但是,当我从init.d脚本执行此Node.js(v0.10.4)脚本作为守护程序时,未设置exec回调中的stdout返回值。我该如何解决这个问题?

node.js脚本:

var exec = require('child_process').exec;
setInterval(function()
{
exec('get_switch_state', function(err, stdout, stderr) 
{
        if(stdout == "on")
        {
            // Do something.
        }
});
}, 5000);

init.d脚本:

#!/bin/bash

NODE=/development/nvm/v0.10.4/bin/node
SERVER_JS_FILE=/home/blahname/app/index.js
USER=root
OUT=/home/pi/nodejs.log

case "$1" in

start)
    echo "starting node: $NODE $SERVER_JS_FILE"
    sudo -u $USER $NODE $SERVER_JS_FILE > $OUT 2>$OUT &
    ;;

stop)
    killall $NODE
    ;;

*)
    echo "usage: $0 (start|stop)"
esac

exit 0

1 个答案:

答案 0 :(得分:0)

我最终没有使用Node.js exec child_process。我修改了上面的init.d脚本(/etc/init.d/node-app.sh),如下所示:

#!/bin/bash

NODE=/home/pi/development/nvm/v0.10.4/bin/node
SERVER_JS_FILE=/home/pi/development/mysql_test/index.js
USER=pi
OUT=/home/pi/development/mysql_test/nodejs.log

case "$1" in

start)
echo "starting node: $NODE $SERVER_JS_FILE"
sudo -u $USER TZ='PST' $NODE $SERVER_JS_FILE > $OUT 2>$OUT &
;;

stop)
killall $NODE
;;

*)
echo "usage: $0 (start|stop)"
esac

exit 0

此脚本在启动时启动Node.js应用程序“index.js”,并且按预期方式工作。