nginx+php 出現502 bad gateway,一般這都不是nginx的問題,而是由於 fastcgi或者php的問題導致的,常見的有以下幾種。
1. php.ini 的memory_limit 過小(如果有個別php程式進程需要佔用極大記憶體時這個必須注意)
2. php-fpm.conf 中max_children或者max_requests 設定不合理(設定過小會因為沒有足夠的cgi進程處理請求,設定過大會出現一會兒有響應正常,一會兒等很久才有響應的情況,一般情況下children 按 照記憶體計算,比如說1G設定64,2G128。這個根據實際情況自行調整。
另外檢視當前的PHP FastCGI進程數是否夠用的命令為:netstat -anpo |grep “php-cgi” | wc -l 如果實際使用的“FastCGI進程數”接近預設的“FastCGI進程 數”,那麼,說明“FastCGI進程數”不夠用,需要增大。)
3. 檢視nginx錯誤紀錄檔,發現 pstream sent too big header while reading response headerfrom upstream ,則檢查client head buffer,fastcgi buffer size是否過小,可設定為32K。
4. php 程式執行時間過長而超時,檢查nginx和fastcgi中各種timeout設定。
(nginx 中的 fastcgi_connect_timeout 300;fastcgi_send_timeout 300 :fastcgi_read_timeout300; keepalive_timeout ; php-fpm中的request_terminate_timeout,php.ini中的max_execution_time)
5. php-fpm 有一個引數 max_requests ,該引數指明了每個children最多處理多少個請求後便會被關閉。在大量處理請求下,如果該值設定過小會導致 children頻繁的自殺和建立而浪費 大量時間,若所有的children差不多都在這個時候自殺,則重建前將沒有children響應請求,於是出現502 。可以將該值設定大一些或者是0[無限]。
以上就是php連線資料庫出現502錯誤的詳細內容,更多請關注TW511.COM其它相關文章!