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后端程序的时候,传递的环境变量不全面导致的问题。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值