将PHP从5.3.28升级到5.3.29时Nginx出现502错误


Posted in PHP onMay 09, 2015

今天将PHP从5.3.28升级到5.3.29,发现网站打不开了,提示”502 bad gateway”,访问静态资源可以,但访问任何PHP文件都会502。
其实之前也发现这个问题,只是一直没找到解决办法,所以我一直将PHP保持在5.3.28版本。
按照我以前的脾气,我什么软件都得要最新的稳定版,但PHP之类的软件是例外,因为版本高了,会导致很多程序不兼容,相对来说5.3兼容性算是最好的版本之一,当然5.2也可以。
强迫症实在受不了,官方说5.3.29是5.3的最后一个版本,最后一个版本出现这种问题又一直没解决让我很难受。
网上搜索了一下,没人出现我这种问题,所有的编译过程,配置过程,都是照旧,之前从5.3.25一直到5.3.28都是用的我写的同一个升级脚本,按道理同一个子版本系列,一样的编译和配置过程,不应该出现问题的。
为何5.3.25一直到5.3.28都没问题,到了5.3.29就没问题了呢?
今天终于把问题的根源找到了,我也是醉了……
由于我不想占用额外的端口,所以Nginx和PHP-FPM之间一直使用的Unix socket,而且据说这种方式效率也高一些。
PHP升级到5.3.29以后,出现502错误,而且是一打开网页就报错了,不像是由于PHP执行超时导致的Nginx提示502,更像是PHP-FPM异常终止了,或者是Ngxin根本没有连接上fastcgi。
使用PHP-FPM的日志也是郁闷,我明明开启了日志,还设置了日志路径,但还是没有生成日志。

好吧,根据前面的思路推测出来的原因找问题:

1.PHP-FPM一开始工作就异常终止了;
2.Ngxin根本没有连接上fastcgi。

第一种可能直接就排除了,因为出现502错误的时候,后台的PHP-FPM进程并没有退出,还存活得好好的。
那么很可能是第二种可能了,我把Nginx和PHP-FPM的配置文件修改了一下,改成了传统的“地址:端口”的形式

PHP-FPM配置文件中:

listen = 127.0.0.1:1234

Nginx配置文件中:

fastcgi_pass 127.0.0.1:1234

重启服务,网站竟然顺利打开了。

看来就是Nginx没有连接上PHP-FPM了,那么问题出在哪里呢?难道5.3.29去掉了Unix socket的连接方式?我觉得不大可能,查阅更新日志,也没有看到有关的项目啊。

我将Nginx和PHP-FPM的配置文件改回去。
PHP-FPM配置文件中:
listen = /tmp/php-cgi.sock
Nginx配置文件中:
fastcgi_pass unix:/tmp/php-cgi.sock;
重启服务,立马又502了。

首先想到了检查权限,反正是测试,所以我二话不说直接把那个PHP-FPM的sock文件权限改为777。
chmod 777 /tmp/php-cgi.sock
直接打开网页,能打开!

好吧,就是权限问题了,重启服务,查看php-cgi.sock 的权限

-rwx------. 1 root root 663 9月 18 00:16 php-cgi.sock
这。。。原因已经很明了了,怪不得Nginx连不上PHP-FPM,php-cgi.sock的权限竟然是700,
但问题来了,为什么同样的编译和配置过程,5.3.28之前的版本就没问题呢?我查看另一台没有升级5.3.29的服务器:
srw-rw-rw- 1 root root 0 9月 16 21:11 php-cgi.sock
发现其权限是666,这……无法理解了……为什么5.3.28的默认权限配置是666,到了5.3.29就变成700了呢?
查阅PHP文档,找到解决办法

将PHP-FPM里的配置文件加入,前两项是指定php-cgi.sock的拥有者和用户组,后一项是指定文件权限。
listen.owner = www
listen.group = www
listen.mode = 0666
重启服务,问题解决。

PHP 相关文章推荐
php INI配置文件的解析实现分析
Jan 04 PHP
php设计模式 State (状态模式)
Jun 26 PHP
探讨PHP使用eAccelerator的API开发详解
Jun 09 PHP
PHP图像处理之使用imagecolorallocate()函数设置颜色例子
Nov 19 PHP
WordPress主题制作之模板文件的引入方法
Dec 28 PHP
PHP简单日历实现方法
Jul 20 PHP
Yii2.0 Basic代码中路由链接被转义的处理方法
Sep 21 PHP
PHP中empty,isset,is_null用法和区别
Feb 19 PHP
总结的一些PHP开发中的tips(必看篇)
Mar 24 PHP
PHP使用第三方即时获取物流动态实例详解
Apr 27 PHP
Laravel框架使用Seeder实现自动填充数据功能
Jun 13 PHP
PHP7 字符串处理机制修改
Mar 09 PHP
php序列化函数serialize() 和 unserialize() 与原生函数对比
May 08 #PHP
php中header跳转使用include包含解决参数丢失问题
May 08 #PHP
PHP中is_file()函数使用指南
May 08 #PHP
PHP5.2下preg_replace函数的问题
May 08 #PHP
PHP中is_dir()函数使用指南
May 08 #PHP
php中file_exists函数使用详解
May 08 #PHP
PHP时间和日期函数详解
May 08 #PHP
You might like
第十五节--Zend引擎的发展
2006/11/16 PHP
php从文件夹随机读取文件的方法
2015/06/01 PHP
PDO::getAttribute讲解
2019/01/28 PHP
mac pecl 安装php7.1扩展教程
2019/10/17 PHP
JQuery 写的个性导航菜单
2009/12/24 Javascript
Js切换功能的简单方法
2010/11/23 Javascript
Jquery Ajax xmlhttp请求成功问题
2015/02/04 Javascript
简介JavaScript中用于处理正切的Math.tan()方法
2015/06/15 Javascript
通过V8源码看一个关于JS数组排序的诡异问题
2017/08/14 Javascript
使用3D引擎threeJS实现星空粒子移动效果
2020/09/13 Javascript
微信小程序使用checkbox显示多项选择框功能【附源码下载】
2017/12/11 Javascript
layer.open 按钮的点击事件关闭方法
2018/08/17 Javascript
一次Webpack配置文件的分离实战记录
2018/11/30 Javascript
Layui表格监听行单双击事件讲解
2019/11/14 Javascript
el-table树形表格表单验证(列表生成序号)
2020/05/31 Javascript
Vue3新特性之在Composition API中使用CSS Modules
2020/07/13 Javascript
jQuery实现放大镜案例
2020/10/19 jQuery
[10:18]2018DOTA2国际邀请赛寻真——Fnatic能否笑到最后?
2018/08/14 DOTA
[01:02:54]完美世界DOTA2联赛PWL S2 FTD vs GXR 第一场 11.22
2020/11/26 DOTA
深入理解Python3 内置函数大全
2017/11/23 Python
python中实现数组和列表读取一列的方法
2018/04/03 Python
python/sympy求解矩阵方程的方法
2018/11/08 Python
Linux下安装python3.6和第三方库的教程详解
2018/11/09 Python
python内置数据类型之列表操作
2018/11/12 Python
Django 接收Post请求数据,并保存到数据库的实现方法
2019/07/12 Python
Python接口测试文件上传实例解析
2020/05/22 Python
Pytorch - TORCH.NN.INIT 参数初始化的操作
2021/02/27 Python
纯CSS3大转盘抽奖示例代码(响应式、可配置)
2017/01/13 HTML / CSS
C#基础面试题
2016/10/17 面试题
检查接待方案
2014/02/27 职场文书
文明礼仪演讲稿
2014/05/12 职场文书
爱国主义电影观后感
2015/06/18 职场文书
二婚主持词
2015/06/30 职场文书
2016年圣诞节活动总结范文
2016/04/01 职场文书
python异步的ASGI与Fast Api实现
2021/07/16 Python
Python使用Beautiful Soup(BS4)库解析HTML和XML
2022/06/05 Python