0

如果我从命令行(节点 index.js)运行它,这将按预期工作。但是,当我将这个 Node.js (v0.10.4) 脚本作为来自 init.d 脚本的守护进程执行时,未设置 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
4

1 回答 1

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”,一切都按预期工作。

于 2013-05-07T20:13:21.823 回答