recv() failed (104: Connection reset by peer) while reading response header from upstream

場景:
      爲了獲得用戶在線等實時信息,在客戶端作了個ajax輪訓,每隔5秒請求一次;
用戶量一上來,因而問題就來了,頁面各類卡

nginx日誌文件
[root@iZt web]# tail -f /data/log/nginx_error.log
2017/06/16 19:20:28 [error] 230555#0: *10228041 recv() failed (104: Connection reset by peer) 
while reading response header from upstream,client: 42.19.1.114, server: 47.18.212.1, request: 
"POST /api-chat/subshade?rnd=880 HTTP/1.1", upstream: "fastcgi://127.0.0.1:9000",
 host: "www.1j008.com", referrer: "http://www.2008.com/6166"
.......狂刷此錯誤

php日誌文件 [root@iZt web]# tail
-f /data/log/php-fpm.log [19-Jun-2017 10:51:05] WARNING: [pool www] child 754153 exited on signal 11 (SIGSEGV) after 74.433547 seconds from start [19-Jun-2017 10:51:05] NOTICE: [pool www] child 755405 started .......狂刷此錯誤 百度谷歌後分析結果,大意以下幾點: 1. php程序執行時間超過php-fpm.conf 中 request_terminate_timeout = 300;設置的值,而後php-fpm進程當即退出,
此時nginx得不到php-fpm進程的正確結果,響應502 解決方法: 改request_terminate_timeout 0;不限制超時 2. php-fpm進程數量來不及處理。 解決方法: 增大php-fpm進程數 3. 由於每一個php-fpm在處理必定數量請求後自動stop,而後create new php-fpm 解決方法: 改pm.max_requests限制 ..... 對應一下個人日誌看來,網上的症狀確實與個人同出一轍。 竊喜.....
沒多久發現不對,對應着改了一輪下來,各類服務重啓, 問題依舊、 好;既然無果那麼就分析一下php
-fpm瘋狂的終止緣由 [root@iZt web]#dmesg ...... php-fpm[744779]: segfault at 1c ip 00000000007a8ea1 sp 00007ffe40af5330 error 4 in php-fpm[400000+9a9000] php-fpm[744924]: segfault at 10bc890 ip 000000000078931f sp 00007ffe40af56e8 error 4 in php-fpm[400000+9a9000] php-fpm[746677]: segfault at 1c ip 00000000007a8ea1 sp 00007ffe40af5330 error 4 in php-fpm[400000+9a9000] php-fpm[746738]: segfault at 0 ip 00000000007a8ead sp 00007ffe40af5330 error 6 in php-fpm[400000+9a9000] php-fpm[746371] general protection ip:7a8ead sp:7ffe40af5330 error:0 in php-fpm[400000+9a9000] 好了,問題找到 在php裏面我確實處理過客戶端ip 相似$_SERVER['REMOVE_ADDR']方法獲得的ip 通過ip2long ( string $ip_address )轉換時出錯, 由於 $ip_address = "這裏的ip不合符規則裏面有逗號" 過濾之.... 安靜了
相關文章
相關標籤/搜索