概述
项目因功能开发需要调用独立的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排查了发现都没有问题。
总结
最终发现是环境变量(process.env)导致的问题。脱离壳程序后,process.env和当前用户的环境变量一致,故而可以找到node程序(NodeJS的bin目录是写在PATH环境变量中);在壳程序的运行环境里,process.env只有很少的几个,故而导致node执行程序没有找到,根源应该是壳程序启动Web后端程序的时候,传递的环境变量不全面导致的问题。