天天看點

通路線上平台出現http狀态碼“502”和“504”HTTP協定

某一天在通路線上平台的時候,突然發現進不去了,加載了好大一會先是出現“502 Bad Gateway”(網關錯誤), 過了一會再去通路出現“504 Gateway Time-out”(網關逾時),現在就這兩個狀态出現的原因和解決辦法進行分析。

一、出現“502”

網頁顯示:

通路線上平台出現http狀态碼“502”和“504”HTTP協定

原因:(以下都有可能,原因并不唯一)

1. upstream連接配接失敗,可能後端服務沒有開啟,屬于應用服務的問題(前提是接入層7層正常的情況下)。

2. SSL初始化或者握手失敗,可能證書不正确

3. 發送請求時,和upstream的連接配接已經斷掉

4. 從upstream中recv資料失敗或者長度為0或者eof

5. upstream中recv的資料太大或者不是有效的HTTP header

上面的話可能一般人不了解,其中某位部落客給的解釋很好了解也比較準确:“後端伺服器tomcat沒有起來,應用服務的問題(前提是接入層7層正常的情況下)。

應用服務問題一種是應用本身問題;另一種是因為依賴服務問題比如依賴服務RT高,依賴的服務有大的讀取(mysql慢查,http等),以至于調用方超過逾時read時間;服務叢集壓力大時,也會出現502逾時(502了解為不可響應或響應不過來,其實還是不可響應)。”雖然和後端服務建立聯系,但是無法給予正常的響應,是以報錯。

解決辦法:

1.加大後端服務單個業務請求的執行的時間,具體是後端擴容或者前端限流 

場景可能是:使用者在查詢資料時,本來後端跟前端是做大查詢的條數是10萬條,可是使用者不知道,直接查了近三年的資料,足足有1億多條,服務分分鐘就挂了

2.後端适當将php-cgi程序數設定多點,需要修改/usr/local/php/etc/php-fpm.conf 将其中的max_children值适當增加。

3.增大緩沖區

fastcgi_buffers 8 16k;
fastcgi_buffer_size 32k;      

4.增大代理緩沖區

5.增加php逾時時間,php.ini 中預設的最長執行時間是 30 秒,即使morenmax_execution_time=30,适當增大這一數值

6.增加nginx等待時間:

http{
    ...
    fastcgi_connect_timeout 300;//連接配接
    fastcgi_send_timeout 300;//發送請求
    fastcgi_read_timeout 300;//發送輸出
    ...
}      

7.後端檢視并處理死掉的程序

二、出現“504”

網頁顯示:

通路線上平台出現http狀态碼“502”和“504”HTTP協定

原因:

大佬解釋:

“504 gateway time-out 顧名思義 網關逾時 一般計算機中的逾時就是配置錯了,此處一般指nginx做反向代理伺服器時,所連接配接的伺服器tomcat無響應導緻的。

從網絡角度,502已經與後端建立了連接配接,但逾時;504與後端連接配接未建立,逾時。” ​​伺服器​​作為網關或代理,但是沒有及時從上遊伺服器收到請求。上遊伺服器已關閉,也就是不響應網關或者代理

解決辦法:

1.nginx中配置:

(1) 增大以下逾時時間的值。預設都是60s。

http{
    ...
    fastcgi_connect_timeout 300;//連接配接
    fastcgi_send_timeout 300;//發送請求
    fastcgi_read_timeout 300;//發送輸出
    ...
}      

(2) 優化性能參數設定,适當将fastcgi以下參數變大:

http {
    ...
    fastcgi_buffer_size=128k;
    fastcgi_buffers 2 256k;
    fastcgi_busy_buffers_size 256k;
    fastcgi_temp_file_write_size 256k;
    ...
}      

2.php中配置:

(1)php.ini

設定max_execution_time值

(2)php-fpm

通過計算适當增大max_children(php-cgi最大程序數)、request_terminate_timeout(處理腳本的逾時時間)的值,

注意:以下的值并不是通用的,需要計算(​​計算詳情請點選​​)

max_children 40
request_terminate_timeout 900      

三、常見的HTTP協定以及http狀态碼:

​​HTTP協定​​

參考:

【1】​​前端報502 bad gateway的原因及解決方案​​

【2】​​http 502 和 504 的差別​​

【3】​​http狀态碼502與504差別​​