最近在项目中遇到一个很诡异的问题,通过一台上海的服务器调用php命令行,去向陕西的服务器请求数据,一直报连接失败的错误。
首先,通过命令行直接执行php脚本,没有问题;
其次,通过其他服务器请求,也没有问题;
通过追代码,发现是使用了Snoopy插件做的请求。debug后发现问题出在插件的这行代码:
exec($this->curl_path." -k -D \"$headerfile\"".$cmdline_params." \"".escapeshellcmd($URI)."\"",$results,$return);

在项目中遇到通过PHP命令行执行请求时遇到连接失败问题,经排查发现是Snoopy插件在使用exec函数时,由于SIGCHLD信号处理导致返回状态值为-1。当子进程先于父进程结束,若父进程忽略SIGCHLD信号,exec会返回-1。解决方案是在执行exec前清除信号处理函数,执行后再恢复,这样可以获取正确的退出状态。
最低0.47元/天 解锁文章
560

被折叠的 条评论
为什么被折叠?



