Nginx 502 Bad Gateway 的錯(cuò)誤已經(jīng)遇到好幾次了,這里做一下記錄,備忘哈哈。

會(huì)有好多種情況出現(xiàn)502錯(cuò)誤,下面我們分情況來說一下。
一、fastcgi緩沖區(qū)設(shè)置過小
出現(xiàn)錯(cuò)誤,首先要查找nginx的日志文件,目錄為/var/log/nginx,在日志中發(fā)現(xiàn)了如下錯(cuò)誤。
2013/01/17 13:33:47 [error] 15421#0: *16 upstream sent too big header while reading response header from upstream
查閱了一下資料,大意是nginx緩沖區(qū)有一個(gè)bug造成的,我們網(wǎng)站的頁(yè)面消耗占用緩沖區(qū)可能過大。
網(wǎng)上查找了一下解決方法,在國(guó)外網(wǎng)站看到了一個(gè)增加緩沖區(qū)的方法,徹底解決了Nginx 502 Bad Gateway的問題。方法如下:
http {
...
fastcgi_buffers 8 16k;
fastcgi_buffer_size 32k;
...
}
請(qǐng)根據(jù)服務(wù)器已經(jīng)網(wǎng)站的情況自行增大上述兩個(gè)配置項(xiàng)。
二、代理緩沖區(qū)設(shè)置過小
如果你使用的是nginx反向代理,如果header過大,超出了默認(rèn)的1k,就會(huì)引發(fā)上述的upstream sent too big header (說白了就是nginx把外部請(qǐng)求給后端處理,后端返回的header太大,nginx處理不過來就會(huì)導(dǎo)致502。
server {
listen 80;
server_name *.lxy.me;
location / {
###############添加這3行
proxy_buffer_size 64k;
proxy_buffers 32 32k;
proxy_busy_buffers_size 128k;
###############添加這3行
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
............
}
三、默認(rèn)php-cgi的進(jìn)程數(shù)設(shè)置過少
在安裝好使用過程中出現(xiàn)502問題,一般是因?yàn)槟J(rèn)php-cgi進(jìn)程是5個(gè),可能因?yàn)閜hpcgi進(jìn)程不夠用而造成502,需要修改/usr/local/php/etc/php-fpm.conf 將其中的max_children值適當(dāng)增加。也有可能是max_requests值不夠用。需要說明的是這連個(gè)配置項(xiàng)占用內(nèi)存很大,請(qǐng)根據(jù)服務(wù)器配置進(jìn)行設(shè)置。否則可能起到反效果。
四、php執(zhí)行超時(shí)
php執(zhí)行超時(shí),修改/usr/local/php/etc/php.ini 將max_execution_time 改為300
五、nginx等待時(shí)間超時(shí)
部分PHP程序的執(zhí)行時(shí)間超過了Nginx的等待時(shí)間,可以適當(dāng)增加nginx.conf配置文件中FastCGI的timeout時(shí)間
http {
fastcgi_connect_timeout 300;
fastcgi_send_timeout 300;
fastcgi_read_timeout 300;
.....
}
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。