本文是小O在开发过程中遇到的问题,根据网友总结的资料和自己的实际环境解决了.
Nginx的error.log输出的错误是:
[error]752#0: *1 upstream prematurely closed connection while reading response headerfrom upstream, client: 127.0.0.1, server: hxm.com, request: "POST/api/v1/token/user HTTP/1.1", upstream:"fastcgi://unix:/usr/local/var/run/nginx/php-cgi.sock:", host: "hxm.com"
/api/v1/token/user方法会去curl请求一个HTTPS的地址,输出的错误,小O的问题是环境问题,php-fpm没有启动的用户跟Nginx不一致导致的,所以只要关闭php-fpm进程,在指定用户重启php-fpm进程即可;
suod pkill php-fpm
cd /usr/local/opt/php71/sbin
sudo ./php-fpm
以下是网上的几种解决办法,仅供参考
检查PHP版本,nginx下的php函数curl请求Https报错502升级php到5.3以上包括5.3即可
检查Nginx版本
检查curl版本
检查openssl的版本
权限问题,运行时的文件权限问题,有程序文件,Nginx的文件(/usr/local/var/run/nginx/php-cgi.sock)
查一查