欧美一区2区三区4区公司二百,国产精品婷婷午夜在线观看,自拍偷拍亚洲精品,国产美女诱惑一区二区

歡迎來到云服務(wù)器

服務(wù)器租用

Nginx處事器呈現(xiàn)502錯誤的原因息爭決步伐總結(jié)

一些運行在Nginx上的網(wǎng)站有時候會呈現(xiàn)“502 Bad Gateway”錯誤,有些時候甚至頻繁的呈現(xiàn)。有些站長是在方才轉(zhuǎn)移到Nginx之后就呈現(xiàn)了這個問題,所以常常會猜疑這是不是Nginx的問題,但事實上這是個誤區(qū)。

Nginx處事器呈現(xiàn)502錯誤的原因息爭決步伐總結(jié)

以下是從張宴和Ayou的博客匯集整理的一些Nginx 502錯誤的排查要領(lǐng),供各人參考:

Nginx 502錯誤的原因較量多,是因為在署理模式下后端處事器呈現(xiàn)問題引起的。這些錯誤一般都不是nginx自己的問題,必然要從后端找原因!但nginx把這些墮落都攬在本身身上了,著實讓nginx的推廣者備受置疑,究竟從字眼上領(lǐng)略,bad gateway?不就是bad nginx嗎?讓不相識的人看到,會直接把責(zé)任推在nginx身上,但愿nginx下一個版本會把墮落提示寫稍微友好一些,至少不會是此刻簡樸的一句502 Bad Gateway,別的還不忘附上本身的臺甫。

Nginx 502的觸發(fā)條件

502錯誤最凡是的呈現(xiàn)環(huán)境就是后端主機(jī)當(dāng)機(jī)。在upstream設(shè)置里有這么一項設(shè)置:proxy_next_upstream,這個設(shè)置指定了nginx在從一個后端主機(jī)取數(shù)據(jù)碰著何種錯誤時會轉(zhuǎn)到下一個后端主機(jī),里頭寫上的就是會呈現(xiàn)502的所有環(huán)境拉,默認(rèn)是error timeout。error就是當(dāng)機(jī)、斷線之類的,timeout就是讀取堵塞超時,較量容易領(lǐng)略。我一般是全寫上的:

proxy_next_upstream error timeout invalid_header http_500 http_503;

不外此刻大概我要去掉http_500這一項了,http_500指定后端返回500錯誤時會轉(zhuǎn)一個主機(jī),后端的jsp墮落的話,原來會打印一堆stacktrace的錯誤信息,此刻被502代替了。但公司的措施員可不這么認(rèn)為,他們認(rèn)定是nginx呈現(xiàn)了錯誤,我實在沒空跟他們表明502的道理了……

503錯誤就可以保存,因為后端凡是是apache resin,假如apache死機(jī)就是error,但resin死機(jī),僅僅是503,所以照舊有須要保存的。

辦理步伐

碰著502問題,可以優(yōu)先思量憑據(jù)以下兩個步調(diào)去辦理。

1、查察當(dāng)前的PHP FastCGI歷程數(shù)是否夠用

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

假如實際利用的“FastCGI歷程數(shù)”靠近預(yù)設(shè)的“FastCGI歷程數(shù)”,那么,說明“FastCGI歷程數(shù)”不足用,需要增大。

2、部門PHP措施的執(zhí)行時間高出了Nginx的期待時間

可以適當(dāng)增加nginx.conf設(shè)置文件中FastCGI的timeout時間,譬喻:

......

http

{

......

fastcgi_connect_timeout 300;

fastcgi_send_timeout 300;

fastcgi_read_timeout 300;

......

}

......

php.ini中memory_limit設(shè)低了會墮落,修改了php.ini的memory_limit為64M,重啟nginx,發(fā)明好了,本來是PHP的內(nèi)存不敷了。

假如這樣修改了還辦理不了問題,可以參考下面這些方案

3、max-children和max-requests

一臺處事器上運行著nginx php(fpm) xcache,會見量日均 300W pv閣下

最近常常會呈現(xiàn)這樣的環(huán)境: php頁面打開很慢,cpu利用率溘然降至很低,系統(tǒng)負(fù)載溘然升至很高,查察網(wǎng)卡的流量,也會發(fā)明溘然降到了很低。這種環(huán)境只一連數(shù)秒鐘就規(guī)復(fù)了

查抄php-fpm的日志文件發(fā)明白一些線索:

Sep3008:32:23.289973[NOTICE] fpm_unix_init_main(), line 271: getrlimit(nofile): max:51200, cur:51200

Sep3008:32:23.290212[NOTICE] fpm_sockets_init_main(), line 371:using inherited socket fd=10,“127.0.0.1:9000″

Sep3008:32:23.290342[NOTICE] fpm_event_init_main(), line 109: libevent:using epoll

Sep3008:32:23.296426[NOTICE] fpm_init(), line 47: fpm is running, pid 30587
http://www.server110.com/nginx/201312/4409.html

在這幾句的前面,是1000多行的封鎖children和開啟children的日志

本來,php-fpm有一個參數(shù) max_requests,該參數(shù)指明白,每個children最多處理懲罰幾多個請求后便會被封鎖,默認(rèn)的配置是500。因為php是把請求輪詢給每個children,在大流量下,每個childre達(dá)到max_requests所用的時間都差不多,這樣就造成所有的children根基上在同一時間被封鎖。

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

辦理問題很簡樸,增加children的數(shù)量,而且將 max_requests 配置未 0 可能一個較量大的值:

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

調(diào)大以下兩個參數(shù)(按照處事器實際環(huán)境,過大也不可)

<valuename=”max_children”>5120</value>

<valuename=”max_requests”>600</value>

然后重啟php-fpm。

5、增加緩沖區(qū)容量巨細(xì)
騰訊云代理

Copyright © 2003-2021 MFISP.COM. 國外vps服務(wù)器租用 夢飛云服務(wù)器租用 版權(quán)所有 ? 粵ICP備11019662號

主站蜘蛛池模板: 黔东| 奉贤区| 兴文县| 松江区| 肥城市| 禹州市| 睢宁县| 甘谷县| 邵阳县| 荥经县| 孟州市| 定边县| 灵宝市| 沿河| 莲花县| 长子县| 沅江市| 土默特左旗| 彩票| 芦溪县| 平原县| 汉中市| 文化| 舒兰市| 无为县| 图们市| 民县| 大丰市| 宝山区| 海淀区| 晋中市| 和硕县| 库尔勒市| 板桥市| 怀集县| 洛宁县| 伊宁县| 淮安市| 八宿县| 四平市| 彭州市|