php-fpm报502问题「建议收藏」

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"

 

这个是nginx的错误日志

备注: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的配置文件中加上一下代码

location ~\.php$ {  
    root /root/wwwroot;  
    fastcgi_pass unix:/tmp/php-cgi.sock;  
    fastcgi_index index.php;  
    include fastcgi.conf;  
} 

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

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

这里写图片描述

再次重启ngix和php-fpm,问题解决
这里写图片描述

总结:
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、其实我们不管选择哪一种,主要是针对自己的问题,先要看报错,然后再对症下药,不要这一种试试那一种试试。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/111686.html原文链接:https://javaforall.net

(0)
上一篇 2022年2月17日 上午7:00
下一篇 2022年2月17日 上午7:00


相关推荐

  • 工作流引擎 Activiti 万字详细进阶

    工作流引擎 Activiti 万字详细进阶Activiti 进阶一 流程实例什么是流程实例流程实例 ProcessInsta 代表流程定义的执行实例 一个流程实例包括了所有的运行节点 我们可以利用这个对象来了解当前流程实例的进度等信息 例如 用户或程序按照流程定义内容发起一个流程 这就是一个流程实例 流程定义和流程实例的图解 启动流程实例并添加 Businesskey 业务标识 流程定义部署在 activiti 后 就可以在系统中通过 activiti 去管理该流程的执行 执行流程表示流程的一次执行 比如部署系统出差流程后 如果

    2026年3月18日
    3
  • Python生成随机数矩阵_Python生成50个随机数

    Python生成随机数矩阵_Python生成50个随机数生成随机数使用random模块random.random()用于随机生成一个0到1的浮点数random.randint(start,stop)随机生成[start,stop]区间内的整数代码示例:importrandomprint(random.random())print(random.randint(2,5))输出结果:0.281138941702427152…

    2022年10月4日
    4
  • 如何让AI Agent与人类工作流更好地融合?企业级人机协同实战指南

    如何让AI Agent与人类工作流更好地融合?企业级人机协同实战指南

    2026年3月15日
    3
  • Js:indexOf() 和 lastIndexOf() 的区别[通俗易懂]

    Js:indexOf() 和 lastIndexOf() 的区别[通俗易懂]ECMAScript5为数组实例添加了两个位置方法:indexOf()和lastIndexOf()。这两个方法都接收两个参数:要查找的项和(可选的)表示查找起点位置的索引。indexOf()方法从数组的开头(位置0)开始向后查找lastIndexOf()方法则从数组的末尾开始向前查找。这两个方法都返回要查找的项在数组中的位置,或者在没找到的情况下返回-1。在比较第一个参数与数组中的每一项时,会使用全等操作符;也就是说,要求查找的项必须严格相等(就像使用===一样)。…

    2022年7月14日
    19
  • MATAL角度弧度互换

    MATAL角度弧度互换MATAL 角度弧度互换一 利用 matlab 自身所带的函数进行转换输入 a pi b rad2deg a 弧度转角度 c deg2rad b 角度转弧度输出 b 180 c 3 979 二 自己编写在 MATLAB 中 pi 会直接默认为圆周率 不需要像 C C 一样事先定义输入 a pi b a pi180 弧度转角度 c bpi 180 角度转弧度输出 b 180 c 3 979 第一次写文章 不敢写太复杂的东西 这个很简单的东

    2026年3月19日
    3
  • (2019)OCP 12c 062考试题库出现大量新题-4

    (2019)OCP 12c 062考试题库出现大量新题-4

    2021年7月5日
    90

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号