child_process.exec / spawn使用npm install命令触发回调/关闭(通过Gulp / Shipit)

时间:2015-05-01 14:25:09

标签: node.js promise gulp child-process

  • 我使用Shipit进行部署。
  • 在部署时,Shipit会将当前的Git Sha检出到tmp目录,然后运行npm install,然后运行gulp build,然后继续部署。
  • Shipit使用Orchestrator进行任务流程,就像Gulp一样。
  • Shipit拥有自己的CLI,因此我可以使用shipit development deploy进行部署。

以上所有事情都有效。我尝试做的是创建一个gulp deploy任务,它将直接初始化Shipit,而不是使用CLI。看起来像这样:

gulp.task('shipit:deploy', function() {
  var deployToEnv = argv['deploy-to'] || false;
  var shipit;
  return inquirer.prompt([{
    type: 'list',
    name: 'deployToEnv',
    default: deployToEnv,
    message: 'Deploy to environment:',
    choices: envs
  }]).then(function(answers) {
    deployToEnv = answers.deployToEnv;
    shipit = new Shipit({environment: deployToEnv});
    shipit.initialize();
    shipit.start('deploy');
  });
});

对应的shipit配置:

  shipit.initConfig(config);
  shipit.blTask('build', function() {
    return shipit.local('npm install --silent', {
      cwd: shipit.config.workspace
    }).then(function() {
      return shipit.local('gulp build', {
        cwd: shipit.config.workspace
      });
    });
  });

  shipit.on('fetched', function() {
    shipit.start('build');
  });

事情似乎与一个问题有关:它实际上并没有执行npm install

Running "npm install --silent" on local. Running "gulp build" on local.

所以,npm install命令似乎过早地解决了这个承诺,但我不确定是怎么回事。

我遇到类似的问题(只使用shipit cli)和npm警告,这是我发现使用--silent arg解决了这个问题。

作为测试,我按原样保留了代码,但将npm install --silent替换为sleep 10。果然,它在执行gulp build之前等了10秒钟。因此,它似乎是npm install命令特有的东西。

感谢任何帮助!

更新#1:

shipit.local使用child_process.exec。我尝试将其转换为使用child_process.spawn,但结果相同。

更新#2:

如果我将命令更改为sudo npm install,则事情按预期工作!那么......这是什么意思,我怎样才能避免使用sudo运行它?

更新#3:

如果没有sudo仍然无法执行此操作,但我尝试在这些结果中添加--verbose标记:

没有sudo

@ npm info it worked if it ends with ok
@ npm verb cli [ '/Users/timkelty/.nvm/versions/node/v0.12.0/bin/node',
@ npm verb cli   '/Users/timkelty/.nvm/versions/node/v0.12.0/bin/npm',
@ npm verb cli   'install',
@ npm verb cli   '--verbose' ]
@ npm info using npm@2.5.1
@ npm info using node@v0.12.0
@ npm verb install where, deps [ '/Users/timkelty/tmp/edwards-garment-website', [] ]
@ npm verb install where, peers [ '/Users/timkelty/tmp/edwards-garment-website', [] ]
@ npm info preinstall edwards-garment-website@1.1.0
@ npm info build /Users/timkelty/tmp/edwards-garment-website
@ npm verb linkStuff [ false, false, false, '/Users/timkelty/tmp' ]
@ npm info linkStuff edwards-garment-website@1.1.0
@ npm verb linkBins edwards-garment-website@1.1.0
@ npm verb linkMans edwards-garment-website@1.1.0
@ npm verb rebuildBundles edwards-garment-website@1.1.0
@ npm info install edwards-garment-website@1.1.0
@ npm info postinstall edwards-garment-website@1.1.0
@ npm verb exit [ 0, true ]
@ npm info ok
Running "gulp build" on local.
@ [15:14:32] Local gulp not found in ~/tmp/edwards-garment-website
@ [15:14:32] Try running: npm install gulp
'build' errored after 755 ms
Error: Command failed: /bin/sh -c gulp build

使用sudo

Running "sudo npm install --verbose" on local.
@ npm info it worked if it ends with ok
@ npm verb cli [ '/Users/timkelty/.nvm/versions/node/v0.12.0/bin/node',
@ npm verb cli   '/Users/timkelty/.nvm/versions/node/v0.12.0/bin/npm',
@ npm verb cli   'install',
@ npm verb cli   '--verbose' ]
@ npm info using npm@2.5.1
@ npm info using node@v0.12.0
@ npm verb install where, deps [ '/Users/timkelty/tmp/edwards-garment-website',
@ npm verb install   [ 'Select2',
@ npm verb install     'autoprefixer-core',
@ npm verb install     'babel',

...所以出于某种原因,当没有sudo运行时,npm install命令似乎认为它没有任何依赖安装,所以它完成没有错误并继续我的下一个任务。

2 个答案:

答案 0 :(得分:2)

我找到了解决方案!

问题在于我尝试安装devDependencies,但是当我运行gulp deploy命令时,NODE_ENV设置为production,而不安装devDependencies。

因此,将命令更改为NODE_ENV=development npm install似乎可以解决问题!

答案 1 :(得分:0)

在更新#2之后,我有更多的选择来解释为什么这个组合不起作用/首先,我们需要找出执行命令的用户。为此,您需要执行命令whoami并查看结果(您可以通过ssh或shipit任务执行此操作)。直接的问题是,没有用户可以安装包裹。

可能的解决方案#1:

用户没有权限使用tmp文件夹。我们可以通过ls -ld /path/to/tmp检查它,预期输出:

drwxrwxrwt 13 root root 280 May  8 19:42 /tmp

您需要验证所有用户都可以在tmp目录中写入:drwxrwxrwx。如果没有,您可以设置chmod -R 755

可能的解决方案#2:

npm上的执行仅授予所有者用户/群组,我们的用户没有。我们可以通过ls -lL $(which npm)查看。预期产出:

-rwxr-xr-x 1 root root 1881 Apr 19 07:12 /usr/../lib/node_modules/npm/bin/npm-cli.js

如果文件中没有权限x,则执行sudo chmod +x $(which npm)

<强>更新 在这个question之后,你的tmp文件夹可能也有问题,但是对于npm的调试文件夹。尝试搜索一个&amp;检查许可。

希望它能满足我们的所有选择。