溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

將PHP從5.3.28升級到5.3.29時Nginx出現(xiàn)502錯誤怎么解決

發(fā)布時間:2021-06-30 17:03:41 來源:億速云 閱讀:116 作者:chen 欄目:開發(fā)技術(shù)

這篇文章主要介紹“將PHP從5.3.28升級到5.3.29時Nginx出現(xiàn)502錯誤怎么解決”,在日常操作中,相信很多人在將PHP從5.3.28升級到5.3.29時Nginx出現(xiàn)502錯誤怎么解決問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”將PHP從5.3.28升級到5.3.29時Nginx出現(xiàn)502錯誤怎么解決”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!

今天將PHP從5.3.28升級到5.3.29,發(fā)現(xiàn)網(wǎng)站打不開了,提示”502 bad gateway”,訪問靜態(tài)資源可以,但訪問任何PHP文件都會502。
其實(shí)之前也發(fā)現(xiàn)這個問題,只是一直沒找到解決辦法,所以我一直將PHP保持在5.3.28版本。
按照我以前的脾氣,我什么軟件都得要最新的穩(wěn)定版,但PHP之類的軟件是例外,因?yàn)榘姹靖吡耍瑫?dǎo)致很多程序不兼容,相對來說5.3兼容性算是最好的版本之一,當(dāng)然5.2也可以。
強(qiáng)迫癥實(shí)在受不了,官方說5.3.29是5.3的最后一個版本,最后一個版本出現(xiàn)這種問題又一直沒解決讓我很難受。
網(wǎng)上搜索了一下,沒人出現(xiàn)我這種問題,所有的編譯過程,配置過程,都是照舊,之前從5.3.25一直到5.3.28都是用的我寫的同一個升級腳本,按道理同一個子版本系列,一樣的編譯和配置過程,不應(yīng)該出現(xiàn)問題的。
為何5.3.25一直到5.3.28都沒問題,到了5.3.29就沒問題了呢?
今天終于把問題的根源找到了,我也是醉了……
由于我不想占用額外的端口,所以Nginx和PHP-FPM之間一直使用的Unix socket,而且據(jù)說這種方式效率也高一些。
PHP升級到5.3.29以后,出現(xiàn)502錯誤,而且是一打開網(wǎng)頁就報(bào)錯了,不像是由于PHP執(zhí)行超時導(dǎo)致的Nginx提示502,更像是PHP-FPM異常終止了,或者是Ngxin根本沒有連接上fastcgi。
使用PHP-FPM的日志也是郁悶,我明明開啟了日志,還設(shè)置了日志路徑,但還是沒有生成日志。

好吧,根據(jù)前面的思路推測出來的原因找問題:

1.PHP-FPM一開始工作就異常終止了;
2.Ngxin根本沒有連接上fastcgi。

第一種可能直接就排除了,因?yàn)槌霈F(xiàn)502錯誤的時候,后臺的PHP-FPM進(jìn)程并沒有退出,還存活得好好的。
那么很可能是第二種可能了,我把Nginx和PHP-FPM的配置文件修改了一下,改成了傳統(tǒng)的“地址:端口”的形式

PHP-FPM配置文件中:

listen = 127.0.0.1:1234

Nginx配置文件中:

fastcgi_pass 127.0.0.1:1234

重啟服務(wù),網(wǎng)站竟然順利打開了。

看來就是Nginx沒有連接上PHP-FPM了,那么問題出在哪里呢?難道5.3.29去掉了Unix socket的連接方式?我覺得不大可能,查閱更新日志,也沒有看到有關(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)限,反正是測試,所以我二話不說直接把那個PHP-FPM的sock文件權(quán)限改為777。
chmod 777 /tmp/php-cgi.sock
直接打開網(wǎng)頁,能打開!

好吧,就是權(quá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,
但問題來了,為什么同樣的編譯和配置過程,5.3.28之前的版本就沒問題呢?我查看另一臺沒有升級5.3.29的服務(wù)器
srw-rw-rw- 1 root root 0 9月 16 21:11 php-cgi.sock
發(fā)現(xiàn)其權(quán)限是666,這……無法理解了……為什么5.3.28的默認(rèn)權(quán)限配置是666,到了5.3.29就變成700了呢?
查閱PHP文檔,找到解決辦法

將PHP-FPM里的配置文件加入,前兩項(xiàng)是指定php-cgi.sock的擁有者和用戶組,后一項(xiàng)是指定文件權(quán)限。
listen.owner = www
listen.group = www
listen.mode = 0666
重啟服務(wù),問題解決。

到此,關(guān)于“將PHP從5.3.28升級到5.3.29時Nginx出現(xiàn)502錯誤怎么解決”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識,請繼續(xù)關(guān)注億速云網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI