記一次nginx部署yii2項目時502 bad gateway錯誤的排查


周六閑來無事,就試着安裝和部署下yii2,安裝過程沒什么問題,但部署到nginx上時遇到了502 bad gatewary問題,折騰了半天才搞定。這個問題是我以前在部署yii2時沒有遇到過的,因此記在這里以備忘。

1,安裝和部署環境

操作系統:macOS,php版本:5.6,nginx版本:1.10.1,yii2版本:2.0。

2,yii2的安裝

yii2的安裝很簡單,參考官網的手冊即可。我這里安裝的是yii2-app-advanced(Yii 2 Advanced Project Template),項目地址在github上,按照README中的安裝說明一步一步來就行,這個就不多說了。

3,yii2在nginx上的部署

其實yii2-app-advanced項目README中對於如何部署在nginx上已經說的很清楚了,按照步驟來應該不會有什么問題。但是我部署時偷了個懶,直接把README中nginx的部署參數拿來用了,結果才導致了502 bad gateway的錯誤。

HTTP狀態碼中5打頭的響應代碼都是由於服務器端引起的,所以看下nginx的日志:

error log:

看到upstream: "fastcgi: //127.0.0.1:9090"這里,端口好像不對,於是查看下虛擬主機的配置:

 再看下php-fpm的配置:

果然,是nginx虛擬主機指定的FastCGI服務器監聽端口錯了,這樣就會導致nginx沒有得到FastCGI服務器的響應。所以瀏覽器發出請求時,nginx給瀏覽器返回一個502的狀態碼,告訴瀏覽器上游的FastCGI服務器沒有響應。

4,解決

在nginx的虛擬主機中,把fastcgi_pass指定的端口修改正確,這個錯誤就解決了。

5,總結

(1)HTTP狀態碼5打頭的錯誤是由服務器端引起的,502 bad gateway則是由於作為網關或者代理工作的服務器(web服務器)嘗試執行請求時,從上游服務器(fastcgi服務器)接收到無效的響應。

(2)fastcgi_pass是ngx_http_fastcgi_module模塊的一個配置指令,它指定了fastcgi服務器的地址,nginx文檔中對於它的描述如下:

 1 Syntax:    fastcgi_pass address;
 2 Default:    —
 3 Context:    location, if in location
 4 
 5 Sets the address of a FastCGI server. The address can be specified as a domain name or IP address, and a port:
 6 fastcgi_pass localhost:9000;
 7 
 8 or as a UNIX-domain socket path:
 9 fastcgi_pass unix:/tmp/fastcgi.socket;
10 
11 If a domain name resolves to several addresses, all of them will be used in a round-robin fashion. In addition, an address can be specified as a server group.

 

參考:

HTTP狀態碼

fastcgi_pass


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM