成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Nginx 502錯(cuò)誤觸發(fā)條件與解決辦法匯總

運(yùn)維 系統(tǒng)運(yùn)維
一些運(yùn)行在Nginx上的網(wǎng)站有時(shí)候會出現(xiàn)“502 Bad Gateway”錯(cuò)誤,有些站長是在剛剛轉(zhuǎn)移到Nginx之后就出現(xiàn)了這個(gè)問題,所以經(jīng)常會懷疑這是不是Nginx的問題,但事實(shí)上這是個(gè)誤區(qū)。本文從張宴和Ayou的博客搜集整理的一些Nginx 502錯(cuò)誤的排查方法,供大家參考。

一些運(yùn)行在Nginx上的網(wǎng)站有時(shí)候會出現(xiàn)“502 Bad Gateway”錯(cuò)誤,有些時(shí)候甚至頻繁的出現(xiàn)。有些站長是在剛剛轉(zhuǎn)移到Nginx之后就出現(xiàn)了這個(gè)問題,所以經(jīng)常會懷疑這是不是Nginx的問題,但事實(shí)上這是個(gè)誤區(qū)。

以下是從張宴和Ayou的博客搜集整理的一些Nginx 502錯(cuò)誤的排查方法,供大家參考:

Nginx 502錯(cuò)誤的原因比較多,是因?yàn)樵诖砟J较潞蠖朔?wù)器出現(xiàn)問題引起的。這些錯(cuò)誤一般都不是nginx本身的問題,一定要從后端找原因!但nginx把這些出錯(cuò)都攬?jiān)谧约荷砩狭?,著?shí)讓nginx的推廣者備受置疑,畢竟從字眼上理解,bad gateway?不就是bad nginx嗎?讓不了解的人看到,會直接把責(zé)任推在nginx身上,希望nginx下一個(gè)版本會把出錯(cuò)提示寫稍微友好一些,至少不會是現(xiàn)在簡單的一句502 Bad Gateway,另外還不忘附上自己的大名。

Nginx 502的觸發(fā)條件

502錯(cuò)誤最通常的出現(xiàn)情況就是后端主機(jī)當(dāng)機(jī)。在upstream配置里有這么一項(xiàng)配置:proxy_next_upstream,這個(gè)配置指定了nginx在從一個(gè)后端主機(jī)取數(shù)據(jù)遇到何種錯(cuò)誤時(shí)會轉(zhuǎn)到下一個(gè)后端主機(jī),里頭寫上的就是會出現(xiàn)502的所有情況拉,默認(rèn)是error timeout。error就是當(dāng)機(jī)、斷線之類的,timeout就是讀取堵塞超時(shí),比較容易理解。我一般是全寫上的:

proxy_next_upstream error timeout invalid_header http_500 http_503;

不過現(xiàn)在可能我要去掉http_500這一項(xiàng)了,http_500指定后端返回500錯(cuò)誤時(shí)會轉(zhuǎn)一個(gè)主機(jī),后端的jsp出錯(cuò)的話,本來會打印一堆stacktrace的錯(cuò)誤信息,現(xiàn)在被502取代了。但公司的程序員可不這么認(rèn)為,他們認(rèn)定是nginx出現(xiàn)了錯(cuò)誤,我實(shí)在沒空跟他們解釋502的原理了……

503錯(cuò)誤就可以保留,因?yàn)楹蠖送ǔJ莂pache resin,如果apache死機(jī)就是error,但resin死機(jī),僅僅是503,所以還是有必要保留的。

解決辦法

遇到502問題,可以優(yōu)先考慮按照以下兩個(gè)步驟去解決。

1、查看當(dāng)前的PHP FastCGI進(jìn)程數(shù)是否夠用:

netstat -anpo | grep "php-cgi" | wc -l

如果實(shí)際使用的“FastCGI進(jìn)程數(shù)”接近預(yù)設(shè)的“FastCGI進(jìn)程數(shù)”,那么,說明“FastCGI進(jìn)程數(shù)”不夠用,需要增大。

2、部分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;
......
}
......

php.ini中memory_limit設(shè)低了會出錯(cuò),修改了php.ini的memory_limit為64M,重啟nginx,發(fā)現(xiàn)好了,原來是PHP的內(nèi)存不足了。

如果這樣修改了還解決不了問題,可以參考下面這些方案:

一、max-children和max-requests

一臺服務(wù)器上運(yùn)行著nginx php(fpm) xcache,訪問量日均 300W pv左右

最近經(jīng)常會出現(xiàn)這樣的情況: php頁面打開很慢,cpu使用率突然降至很低,系統(tǒng)負(fù)載突然升至很高,查看網(wǎng)卡的流量,也會發(fā)現(xiàn)突然降到了很低。這種情況只持續(xù)數(shù)秒鐘就恢復(fù)了

檢查php-fpm的日志文件發(fā)現(xiàn)了一些線索

Sep 30 08:32:23.289973 [NOTICE] fpm_unix_init_main(), line 271: getrlimit(nofile): max:51200, cur:51200
Sep 30 08:32:23.290212 [NOTICE] fpm_sockets_init_main(), line 371: using inherited socket fd=10, “127.0.0.1:9000″
Sep 30 08:32:23.290342 [NOTICE] fpm_event_init_main(), line 109: libevent: using epoll
Sep 30 08:32:23.296426 [NOTICE] fpm_init(), line 47: fpm is running, pid 30587

在這幾句的前面,是1000多行的關(guān)閉children和開啟children的日志

原來,php-fpm有一個(gè)參數(shù) max_requests,該參數(shù)指明了,每個(gè)children最多處理多少個(gè)請求后便會被關(guān)閉,默認(rèn)的設(shè)置是500。因?yàn)閜hp是把請求輪詢給每個(gè)children,在大流量下,每個(gè)childre到達(dá)max_requests所用的時(shí)間都差不多,這樣就造成所有的children基本上在同一時(shí)間被關(guān)閉。

在這期間,nginx無法將php文件轉(zhuǎn)交給php-fpm處理,所以cpu會降至很低(不用處理php,更不用執(zhí)行sql),而負(fù)載會升至很高(關(guān)閉和開啟children、nginx等待php-fpm),網(wǎng)卡流量也降至很低(nginx無法生成數(shù)據(jù)傳輸給客戶端)

解決問題很簡單,增加children的數(shù)量,并且將 max_requests 設(shè)置未 0 或者一個(gè)比較大的值:

打開 /usr/local/php/etc/php-fpm.conf

調(diào)大以下兩個(gè)參數(shù)(根據(jù)服務(wù)器實(shí)際情況,過大也不行)

<value name=”max_children”>5120</value>
<value name=”max_requests”>600</value>

然后重啟php-fpm。

二、增加緩沖區(qū)容量大小

將nginx的error log打開,發(fā)現(xiàn)“pstream sent too big header while reading response header from upstream”這樣的錯(cuò)誤提示。查閱了一下資料,大意是nginx緩沖區(qū)有一個(gè)bug造成的,我們網(wǎng)站的頁面消耗占用緩沖區(qū)可能過大。參考老外寫的修改辦法增加了緩沖區(qū)容量大小設(shè)置,502問題徹底解決。后來系統(tǒng)管理員又對參數(shù)做了調(diào)整只保留了2個(gè)設(shè)置參數(shù):client head buffer,fastcgi buffer size。

三、request_terminate_timeout

如果主要是在一些post或者數(shù)據(jù)庫操作的時(shí)候出現(xiàn)502這種情況,而不是在靜態(tài)頁面操作中常見,那么可以查看一下php-fpm.conf設(shè)置中的一項(xiàng):

request_terminate_timeout

這個(gè)值是max_execution_time,就是fast-cgi的執(zhí)行腳本時(shí)間。

0s

0s為關(guān)閉,就是無限執(zhí)行下去。(當(dāng)時(shí)裝的時(shí)候沒仔細(xì)看就改了一個(gè)數(shù)字)

發(fā)現(xiàn),問題解決了,執(zhí)行很長時(shí)間也不會出錯(cuò)了。

優(yōu)化fastcgi中,還可以改改這個(gè)值5s 看看效果。

php-cgi進(jìn)程數(shù)不夠用、php執(zhí)行時(shí)間長、或者是php-cgi進(jìn)程死掉,都會出現(xiàn)502錯(cuò)誤。

如果您還有其他的解決方法,歡迎與編輯溝通!當(dāng)然,如果你的網(wǎng)站并發(fā)量的確很大,那么最終也許需要尋求系統(tǒng)級的解決辦法……

來源:1,2

【編輯推薦】

  1. Web服務(wù)器市場:Apache坐穩(wěn)領(lǐng)頭羊 Nginx持續(xù)走高
  2. Nginx負(fù)載均衡器排障實(shí)錄
  3. Nginx配置與應(yīng)用詳解
責(zé)任編輯:yangsai 來源: 互聯(lián)網(wǎng)
相關(guān)推薦

2010-03-29 17:46:39

Nginx asp

2010-01-30 09:05:11

Windows 7錯(cuò)誤解決

2010-03-24 18:19:42

Nginx php

2010-01-05 18:03:57

2016-02-29 09:57:53

開發(fā)管理錯(cuò)誤辦法

2010-03-26 18:41:51

Nginx 502錯(cuò)誤

2009-12-03 17:36:02

PHP Date()出

2011-04-28 09:54:05

傳真機(jī)

2011-07-27 19:05:35

2016-07-04 14:22:47

DevOps案例軟件

2011-02-22 17:14:20

2010-02-03 16:07:07

Ubuntu Auda

2009-06-03 16:41:21

Eclipse亂碼Eclipse

2011-03-04 13:07:47

Filezilla

2011-08-02 13:46:43

iPhone開發(fā) iPhone SDK

2011-06-17 11:10:51

Qt 中文 輸出

2009-12-07 18:38:16

WCF異常

2009-04-15 10:33:35

SQL Server 性能計(jì)數(shù)器錯(cuò)誤

2009-07-31 09:14:01

WinCE啟動(dòng)失敗

2016-03-01 16:44:52

移動(dòng)開發(fā)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 欧美 中文字幕 | 亚洲人在线观看视频 | 一区二区精品 | 一本大道久久a久久精二百 国产成人免费在线 | 一区在线观看视频 | 欧美一区二区三区久久精品 | 久久久精品网站 | 在线精品一区二区三区 | 国产精品视频网址 | 中文字幕免费视频 | 国产成人免费网站 | 亚洲www啪成人一区二区麻豆 | 日韩 欧美 二区 | 一区二区视频在线 | 精品视频在线免费观看 | 九九热这里 | 欧美电影一区 | 农村真人裸体丰满少妇毛片 | 综合激情av| 中文字幕一区二区三区乱码在线 | 欧美一级片在线观看 | 中文字幕精品一区二区三区在线 | japan25hdxxxx日本 做a的各种视频 | 国产高清精品一区二区三区 | 国产91网站在线观看 | 亚洲精品自在在线观看 | 91免费看片 | 久久免费精彩视频 | 久久中文字幕一区 | 女女百合av大片一区二区三区九县 | 日韩av在线不卡 | 日韩国产精品一区二区三区 | 免费观看av网站 | www.久| 国产精品区一区二区三区 | 久久久久亚洲精品 | 国产精品国产三级国产aⅴ中文 | 日日操av | 久久夜夜 | 欧美性生活视频 | 国产一区在线看 |