当前位置:首页 > PHP教程 > php高级应用 > 列表

php-fpm报502问题的解决办法

发布: 来源: PHP粉丝网  添加日期:2022-04-22 11:42:29 浏览: 评论:0 

这篇文章主要介绍了php-fpm报502问题的解决办法,遇到此类问题的同学,可以参考下。

搭建lnmp完lnmp环境后,测试时出现502报错,看到这个问题,我立刻想到是php-fpm没有起来,但是我用 ps -ef | grep php-fpm 截取 php-fpm 的进程,发现是有的,这时我有查看nginx的错误日志,发现错误信息是:

2017/05/05 17:08:45 [crit] 3258#0: *2 connect() to unix:/tmp/php-cgi.sock failed (2: No such file or directory) while connecting to upstream, client: 192.168.88.1, server: 192.168.88.133, request: "GET /index.php HTTP/1.1", upstream: "fastcgi://unix:/tmp/php-cgi.sock:", host: "192.168.88.134"

php-fpm报502问题的解决办法

备注:php我用的版本是7.1.4的,最新的版本,之前用5.6版本的时候没有出现过这个问题

思路:发现php-fpm的listen是unix sock方式运行的,问题可能出在php-fpm上。既然没有这个文件,就先把文件创建出来

1、创建这个文件,并赋予权限,因为我在编译的时候是用www用户,所以将/tmp/php-cgi.sock的属主和属组都授权为www

touch /tmp/php-cgi.sock

chown www.www /tmp/php-cgi.sock

重启ngix和php-fpm发现还是502的问题

2、我在网上也查看了下,说是其中

fastcgi_pass为配置nginx与php-fpm的交互路径,一般有两种方式

sock方式:fastcgi_pass unix:/tmp/php-cgi.sock;

http方式:fastcgi_pass 127.0.0.1:9000;

任选其中一种即可,但必须和php-fpm的配置一致。

后来我就在nginx的配置文件中加上一下代码

  1. location ~\.php$ {   
  2.  
  3.     root /root/wwwroot;   
  4.  
  5.     fastcgi_pass unix:/tmp/php-cgi.sock;   
  6.  
  7.     fastcgi_index index.php;   
  8.  
  9.     include fastcgi.conf;   

3、同时修改php-fpm的配置文件php-fpm.conf,将listen = 127.0.0.1:9000改为

  1. listen = /tmp/php-cgi.sock 
  2. #这个是设置 /tmp/php-cgi.sock 权限用的 
  3. listen.owner = www 
  4. listen.group = www 
  5. listen.mode = 0660 

php-fpm报502问题的解决办法

再次重启ngix和php-fpm,问题解决

php-fpm报502问题的解决办法

总结:

1、其实这个问题总体就是nginx与php-fpm的交互问题,看我们选择是sock方式还是http方式,但是不管选择哪一种,我们都需要统一

2、我在网上看到有人说将max_children 进程改大,其实这种情况我之前遇到过,它适用于本来php运行正常,突然出现502的问题,这个问题是php-fpm队列满了,出现连接拒绝的错误。如果有问题,可以参考我的博客:http://blog.csdn.net/m0_37886429/article/details/70048754

3、还有人说将php-fpm配置文件里有backlog,backlog是linux服务器在socket处理连接数的定义,phpfpm默认为-1,将-1改为4096,重启php-fpm问题。

4、其实我们不管选择哪一种,主要是针对自己的问题,先要看报错,然后再对症下药,不要这一种试试那一种试试。

Tags: php-fpm报502

分享到: