深入探討:Nginx 502 Bad Gateway錯誤的解決方案_PHP教程

來源:互聯網
上載者:User
max_children=40 , 每個children平均佔用20M-30M記憶體,children越多,可以同時接受的並發數量越多,一般children的值是網站最高並發數+浮動值,這值再×記憶體佔用,就是你需要用到的記憶體。
max_requests = N 是指當每個children接受了N次請求以後,就會把自己殺死,然後重建立立一個children。
PV / max_children = 每一個children接受的request次數[ 預設預設瀏覽一個只調用一次PHP程式,或許非同步呼叫呢?介面呢?]
比如上面的值是1000,而你定義的是10240,那麼fpm要超過10天才能殺死children並重建,這樣如果存在記憶體泄露的話,就會導致進程佔用過多的記憶體而無法釋放,從而使fpm的處理能力降低,還會產生一些莫名其妙的錯誤。
但是如果你把這個值設定的過小,fpm頻繁的殺死children並重建,也會導致額外的開銷。
最好的最佳化當然是根據你網站的運行情況,去不斷的調試,找到一個平衡點。
針對max_children還有一個偷懶的做法, 如果你的php是5.3,那麼你可以把fpm的style設定為apache-like,這個時候children的數量就由fpm自動控制。相應的配置參數是
start_servers:起始進程數量
min_spare_servers:最小進程數量
max_spare_servers:最大進程數量
當伺服器比較閒置時候,fpm會主動殺死一些多餘的children,用來節約資源,當伺服器繁忙的時候,伺服器會自動建立更多的children。
#########################
Nginx 502 Bad Gateway的含義是請求的PHP-CGI已經執行,但是由於某種原因(一般是讀取資源的問題)沒有執行完畢而導致PHP-CGI進程終止,
一般來說Nginx 502 Bad Gateway和php-fpm.conf的設定有關。
php-fpm.conf有兩個至關重要的參數,一個是max_children,
另一個是request_terminate_timeout,但是這個值不是通用的,而是需要自己計算的。
在安裝好使用過程中出現502問題,一般是因為預設php-cgi進程是5個,可能因為phpcgi進程不夠用而造成502,需要修改/usr/local/php/etc/php-fpm.conf 將其中的max_children值適當增加。
計算的方式如下:

如果你的伺服器效能足夠好,且寬頻資源足夠充足,PHP指令碼沒有死迴圈或BUG的話你可以直接將 request_terminate_timeout設定成0s。0s的含義是讓PHP-CGI一直執行下去而沒有時間限制。而如果你做不到這一點,也就 是說你的PHP-CGI可能出現某個BUG,或者你的寬頻不夠充足或者其他的原因導致你的PHP-CGI假死那麼就建議你給request_terminate_timeout賦一個值,這個值可以根據伺服器的效能進行設定。一般來說效能越好你可以設定越高,20分鐘-30分 鐘都可以。

而max_children這個值又是怎麼計算出來的呢?這個值原則上是越大越好,php-cgi的進程多了就會處理的很快,排隊的請求就會很少。 設定max_children也需要根據伺服器的效能進行設定,
一般來說一台伺服器正常情況下每一個php-cgi所耗費的記憶體在20M左右。
按照官方的答案,排查了相關的可能,並結合了網友的答案,得出了下面的解決辦法。
1、查看php fastcgi的進程數(max_children值)
代碼:netstat -anpo | grep “php-cgi” | wc -l
5(假如顯示5)
2、查看當前進程
代碼:top
觀察fastcgi進程數,假如使用的進程數等於或高於5個,說明需要增加(根據你機器實際狀況而定)
3、調整/usr/local/php/etc/php-fpm.conf 的相關設定
10
60s
max_children最多10個進程,按照每個進程20MB記憶體,最多200MB。
request_terminate_timeout執行的時間為60秒,也就是1分鐘。
#################################################
網站運行環境是Nginx +php fastcgi模式的。這幾天運行一直不穩定,總是出錯,報502錯誤。
今天跟以前的同事請教了一下,他告訴我檢查一下php-fpm的日誌,那裡記錄了很多有用的資訊。
於是我檢查了一下,發現確實有很多報錯資訊:
Sep 30 08:32:23.289973 [NOTICE] fpm_unix_init_main(), line 271: getrlimit(nofile): max:51200, cur:51200
如果和nginx.conf : worker_rlimit_nofile 65500; 不一致必須檢查,設定重啟服務
Mar 01 14:39:15.881047 [NOTICE] fpm_children_make(), line 352: child 12364 (pool default) started
Mar 01 14:39:21.715825 [NOTICE] fpm_got_signal(), line 48: received SIGCHLD
Mar 01 14:39:21.715899 [NOTICE] fpm_children_bury(), line 215: child 11947 (pool default) exited with code 0 after 175.443305 seconds from start


有的報錯資訊,就好說了,直接上網查資訊。
經過搜尋,最後總結出以下幾條最佳化策略:
1、提升伺服器的檔案控制代碼開啟開啟
# vi /etc/security/limits.conf 加上
* soft nofile 65500
* hard nofile 65500
2、提升nginx的進程檔案開啟數
nginx.conf : worker_rlimit_nofile 65500;
3、修改php-fpm.conf檔案,主要需要修改2處。
命令 ulimit -n 查看限制的開啟檔案數,php-fpm.conf 中的選項rlimit_files 確保和此數值一致。
10240
65500
4、
# vi /etc/sysctl.conf
底部添加
fs.file-max=65500
經過以上修改,重啟PHP。/usr/local/webserver/php/sbin/php-fpm restart
在查看ulimit -n 是否生效,否則重啟伺服器或者/etc/sysctl.conf、/etc/security/limits.conf的配置生效
到目前為止還沒有出現過以上的報錯資訊。一切運行正常。

http://www.bkjia.com/PHPjc/327220.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/327220.htmlTechArticlemax_children=40 , 每個children平均佔用20M-30M記憶體,children越多,可以同時接受的並發數量越多,一般children的值是網站最高並發數+浮動值,這值再...

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.