NodeJS exec函数执行失败排查

概述

项目因功能开发需要调用独立的JS脚本,在测试的过程中遇到诡异的问题,故而记录下来。

程序启动方式

Web后端的程序通过一个C/C++写的壳程序(下面简称壳程序)利用C/C++ exec*函数启动。

问题表现

Web后端有个API需要单独调用一个JS脚本,API内部使用了child_process.exec函数,第一个参数用的相对路径(node XXX.js param1 param2 这样的形势),诡异的情况是在壳程序的运行环境下,exec调用JS脚本总是会失败,回调函数的错误码(error.code)返回127。脱离壳程序,单独运行Web后端程序功能一切正常。

作了以下排查

  1. 文件目录权限
  2. 目录路径
  3. 环境变量

1和2排查了发现都没有问题。

总结

最终发现是环境变量(process.env)导致的问题。脱离壳程序后,process.env和当前用户的环境变量一致,故而可以找到node程序(NodeJS的bin目录是写在PATH环境变量中);在壳程序的运行环境里,process.env只有很少的几个,故而导致node执行程序没有找到,根源应该是壳程序启动Web后端程序的时候,传递的环境变量不全面导致的问题。

你可能感兴趣的:(Web,前端,javascript,开发语言)