將PHP從5.3.28升級(jí)到5.3.29時(shí)Nginx出現(xiàn)502錯(cuò)誤
今天將PHP從5.3.28升級(jí)到5.3.29,發(fā)現(xiàn)網(wǎng)站打不開(kāi)了,提示”502 bad gateway”,訪(fǎng)問(wèn)靜態(tài)資源可以,但訪(fǎng)問(wèn)任何PHP文件都會(huì)502。
其實(shí)之前也發(fā)現(xiàn)這個(gè)問(wèn)題,只是一直沒(méi)找到解決辦法,所以我一直將PHP保持在5.3.28版本。
按照我以前的脾氣,我什么軟件都得要最新的穩(wěn)定版,但PHP之類(lèi)的軟件是例外,因?yàn)榘姹靖吡?,?huì)導(dǎo)致很多程序不兼容,相對(duì)來(lái)說(shuō)5.3兼容性算是最好的版本之一,當(dāng)然5.2也可以。
強(qiáng)迫癥實(shí)在受不了,官方說(shuō)5.3.29是5.3的最后一個(gè)版本,最后一個(gè)版本出現(xiàn)這種問(wèn)題又一直沒(méi)解決讓我很難受。
網(wǎng)上搜索了一下,沒(méi)人出現(xiàn)我這種問(wèn)題,所有的編譯過(guò)程,配置過(guò)程,都是照舊,之前從5.3.25一直到5.3.28都是用的我寫(xiě)的同一個(gè)升級(jí)腳本,按道理同一個(gè)子版本系列,一樣的編譯和配置過(guò)程,不應(yīng)該出現(xiàn)問(wèn)題的。
為何5.3.25一直到5.3.28都沒(méi)問(wèn)題,到了5.3.29就沒(méi)問(wèn)題了呢?
今天終于把問(wèn)題的根源找到了,我也是醉了……
由于我不想占用額外的端口,所以Nginx和PHP-FPM之間一直使用的Unix socket,而且據(jù)說(shuō)這種方式效率也高一些。
PHP升級(jí)到5.3.29以后,出現(xiàn)502錯(cuò)誤,而且是一打開(kāi)網(wǎng)頁(yè)就報(bào)錯(cuò)了,不像是由于PHP執(zhí)行超時(shí)導(dǎo)致的Nginx提示502,更像是PHP-FPM異常終止了,或者是Ngxin根本沒(méi)有連接上fastcgi。
使用PHP-FPM的日志也是郁悶,我明明開(kāi)啟了日志,還設(shè)置了日志路徑,但還是沒(méi)有生成日志。
好吧,根據(jù)前面的思路推測(cè)出來(lái)的原因找問(wèn)題:
1.PHP-FPM一開(kāi)始工作就異常終止了;
2.Ngxin根本沒(méi)有連接上fastcgi。
第一種可能直接就排除了,因?yàn)槌霈F(xiàn)502錯(cuò)誤的時(shí)候,后臺(tái)的PHP-FPM進(jìn)程并沒(méi)有退出,還存活得好好的。
那么很可能是第二種可能了,我把Nginx和PHP-FPM的配置文件修改了一下,改成了傳統(tǒng)的“地址:端口”的形式
PHP-FPM配置文件中:
listen = 127.0.0.1:1234
Nginx配置文件中:
fastcgi_pass 127.0.0.1:1234
重啟服務(wù),網(wǎng)站竟然順利打開(kāi)了。
看來(lái)就是Nginx沒(méi)有連接上PHP-FPM了,那么問(wèn)題出在哪里呢?難道5.3.29去掉了Unix socket的連接方式?我覺(jué)得不大可能,查閱更新日志,也沒(méi)有看到有關(guān)的項(xiàng)目啊。
我將Nginx和PHP-FPM的配置文件改回去。
PHP-FPM配置文件中:
listen = /tmp/php-cgi.sock
Nginx配置文件中:
fastcgi_pass unix:/tmp/php-cgi.sock;
重啟服務(wù),立馬又502了。
首先想到了檢查權(quán)限,反正是測(cè)試,所以我二話(huà)不說(shuō)直接把那個(gè)PHP-FPM的sock文件權(quán)限改為777。
chmod 777 /tmp/php-cgi.sock
直接打開(kāi)網(wǎng)頁(yè),能打開(kāi)!
好吧,就是權(quán)限問(wèn)題了,重啟服務(wù),查看php-cgi.sock 的權(quán)限
-rwx------. 1 root root 663 9月 18 00:16 php-cgi.sock
這。。。原因已經(jīng)很明了了,怪不得Nginx連不上PHP-FPM,php-cgi.sock的權(quán)限竟然是700,
但問(wèn)題來(lái)了,為什么同樣的編譯和配置過(guò)程,5.3.28之前的版本就沒(méi)問(wèn)題呢?我查看另一臺(tái)沒(méi)有升級(jí)5.3.29的服務(wù)器:
srw-rw-rw- 1 root root 0 9月 16 21:11 php-cgi.sock
發(fā)現(xiàn)其權(quán)限是666,這……無(wú)法理解了……為什么5.3.28的默認(rèn)權(quán)限配置是666,到了5.3.29就變成700了呢?
查閱PHP文檔,找到解決辦法
將PHP-FPM里的配置文件加入,前兩項(xiàng)是指定php-cgi.sock的擁有者和用戶(hù)組,后一項(xiàng)是指定文件權(quán)限。
listen.owner = www
listen.group = www
listen.mode = 0666
重啟服務(wù),問(wèn)題解決。
- Nginx 502 Bad Gateway錯(cuò)誤原因及解決方案
- 詳解php+nginx 服務(wù)發(fā)生500 502錯(cuò)誤排查思路
- 深入分析nginx+php-fpm服務(wù)HTTP狀態(tài)碼502
- 詳解linux中 Nginx 常見(jiàn)502錯(cuò)誤問(wèn)題解決辦法
- 詳解Nginx 502錯(cuò)誤解決辦法
- PHP腳本監(jiān)控Nginx 502錯(cuò)誤并自動(dòng)重啟php-fpm
- Nginx 502 Bad Gateway錯(cuò)誤常見(jiàn)的4種原因和解決方法
- nginx服務(wù)器異常502 bad gateway原因排查
相關(guān)文章
PHP數(shù)組相加操作及與array_merge的區(qū)別淺析
這篇文章主要給大家介紹了關(guān)于PHP數(shù)組相加操作以及與array_merge的區(qū)別,文中通過(guò)示例介紹的很詳細(xì),感興趣的朋友們可以參考學(xué)習(xí),有需要的下面跟著小編一起來(lái)學(xué)習(xí)學(xué)習(xí)吧。2016-11-11
PHP與MySQL開(kāi)發(fā)的8個(gè)技巧小結(jié)
LAMP 架構(gòu)的網(wǎng)站,我以前注重的多是安裝/配置方面的,講述開(kāi)發(fā)的相對(duì)較少,因?yàn)樽约簭氖麻_(kāi)發(fā)也少。看了以后,頗有啟發(fā),以前開(kāi)發(fā)中遇到的一些問(wèn)題,迎刃而解。所以翻譯出來(lái)和大家共享。2010-12-12
PHP創(chuàng)建word文檔的方法(平臺(tái)無(wú)關(guān))
這篇文章主要介紹了PHP創(chuàng)建word文檔的方法,結(jié)合實(shí)例形式分析了與平臺(tái)無(wú)關(guān)的生成word文檔的方法,非常簡(jiǎn)單實(shí)用,需要的朋友可以參考下2016-03-03
WordPress中用于創(chuàng)建以及獲取側(cè)邊欄的PHP函數(shù)講解
這篇文章主要介紹了WordPress中用于創(chuàng)建以及獲取側(cè)邊欄的PHP函數(shù)講解,分別為register_sidebar()函數(shù)和get_sidebar()的使用,需要的朋友可以參考下2015-12-12
PHP ajax 異步執(zhí)行不等待執(zhí)行結(jié)果的處理方法
這篇文章主要介紹了PHP ajax 異步執(zhí)行不等待執(zhí)行結(jié)果的處理方法,本文直接給出實(shí)現(xiàn)代碼,需要的朋友可以參考下2015-05-05
學(xué)習(xí)thinkphp5.0驗(yàn)證類(lèi)使用方法
這篇文章主要介紹了thinkphp5.0驗(yàn)證類(lèi)的簡(jiǎn)單有效的使用方法,一起學(xué)習(xí)下。2017-11-11
PHP接入Apple對(duì)access_token/identityToken進(jìn)行JWT驗(yàn)證流程詳解
JWT(JSON Web Token)是為了在網(wǎng)絡(luò)應(yīng)用環(huán)境間傳遞聲明而執(zhí)行的一種基于JSON的開(kāi)放標(biāo)準(zhǔn)。本文將為大家介紹PHP如何實(shí)現(xiàn)JWT登錄鑒權(quán),需要的可以參考一下2022-09-09
深入理解PHP的遠(yuǎn)程多會(huì)話(huà)調(diào)試
這篇文章主要給大家介紹了關(guān)于PHP遠(yuǎn)程多會(huì)話(huà)調(diào)試的相關(guān)資料,文中通過(guò)示例代碼以及圖片介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2017-09-09

