繁体   English   中英

nodejs exec失败并发出叹息信号

[英]nodejs exec fails with sighup signal

我在nodejs中通过exec创建child_process时遇到错误。 在0.12.x节点版本下运行正常,唯一的变化是将nodejs升级到6.11.3.10次错误中有2次找不到原因和解决方案。 提前致谢

代码详细信息:

   var exec = require('child_process').exec;
   cmd = 'sh /home/ec2-user/bin/lldn start';
   exec(cmd,{ shell: '/bin/bash'},
    function (error, stdout, stderr) {
        if (error) {
            deferred.reject({
                stdout: stdout,
                stderr: stderr,
                error: error,
                cmd: cmd
            });
        } else {
            deferred.resolve({
                stdout: stdout,
                stderr: stderr,
                error: error,
                cmd: cmd
            });
        }
    });

错误详情:

  msg="{ Error: Command failed: sh /home/ec2-
user/logu/datanode/bin/lldn start

at ChildProcess.exithandler (child_process.js:198:12)
at emitTwo (events.js:106:13)
at ChildProcess.emit (events.js:191:7)
at maybeClose (internal/child_process.js:920:16)
at Process.ChildProcess._handle.onexit 
(internal/child_process.js:230:5)
 killed: false,
code: null,
 signal: 'SIGHUP',
cmd: 'sh /home/ec2-user/logu/datanode/bin/lldn start' }"

我用不同的命令遇到了同样的问题,经过一番挖掘之后,我意识到exec隐藏了正确的错误。

我能够显示出在以下位置添加记录器的真正错误:

function (error, stdout, stderr) {
  // Not all three vars are needed, but better to show more
  console.log(error, stdout, stderr);
  if (error) {
    deferred.reject({

我知道这不是解决您特定问题的方法,但希望能对您有所帮助。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM