Node.js child_process无法访问全局模块

问题描述 投票:0回答:1

我在Kubuntu 19.04中全局安装了npm软件包

$ npm install -g cordova
/home/username/.npm-global/bin/cordova -> /home/username/.npm-global/lib/node_modules/cordova/bin/cordova
+ [email protected]
updated 1 package in 7.299s

我可以从外壳访问它

$ cordova -v
9.0.0 ([email protected])

但是我无法使用spawn从简单的节点脚本中访问它:

const { spawn } = require( 'child_process' );
const cmd = spawn( 'cordova', [ '-v' ] );

cmd.stdout.on( 'data', data => {
    console.log( `stdout: ${data}` );
} );

运行它会得到以下结果:

$ node test1.js
events.js:298
      throw er; // Unhandled 'error' event
      ^

Error: spawn cordova ENOENT
    at Process.ChildProcess._handle.onexit (internal/child_process.js:267:19)
    at onErrorNT (internal/child_process.js:467:16)
    at processTicksAndRejections (internal/process/task_queues.js:84:21)
Emitted 'error' event on ChildProcess instance at:
    at Process.ChildProcess._handle.onexit (internal/child_process.js:273:12)
    at onErrorNT (internal/child_process.js:467:16)
    at processTicksAndRejections (internal/process/task_queues.js:84:21) {
  errno: -2,
  code: 'ENOENT',
  syscall: 'spawn cordova',
  path: 'cordova',
  spawnargs: [ '-v' ]
}

但是使用绝对路径时:

const { spawn } = require( 'child_process' );
const cmd = spawn( '/home/username/.npm-global/bin/cordova', [ '-v' ] );

cmd.stdout.on( 'data', data => {
    console.log( `stdout: ${data}` );
} );

我得到了预期的结果:

$ node test1.js
stdout: 9.0.0 ([email protected])

我上面的脚本只是一个测试用例,因为我无法在cordovavue-cli-plugin-cordova中添加/运行quasar特定内容。我追踪到它是问题所在。

更新

我想我找到了问题,但不确定如何解决。将/ bin / bash设置为shell时,它可以工作:

cmd = spawn('cordova', ['-v'], {
    shell: '/bin/bash'
});

不确定,为什么需要这样做,为什么包vue-cli-plugin-cordovaquasar不这样做。

node.js npm spawn
1个回答
0
投票

好吧,经过数小时的研究和尝试,我已经卸载了节点,安装了nvm和最新的节点,设置了

nvm use --delete-prefix v13.7.0 --silent >> /dev/null

并将其添加到~/.bashrc

现在一切正常

© www.soinside.com 2019 - 2024. All rights reserved.