php 高並行報語法錯誤怎麼解決

2022-12-15 10:00:32

php高並行報語法錯誤的解決辦法:1、檢查nginx的設定存取數或者連線數,並增加nginx的兩個引數;2、確認php-fpm的worker程序是否夠用,然後增加worker_connections程序的數量;3、禁用掉記錄的慢紀錄檔即可。

千萬級資料並行如何處理?進入學習

本教學操作環境:Windows10系統、PHP8.1版、Dell G3電腦。

php 高並行報語法錯誤怎麼解決?

Nginx+Php高並行報502、504問題解決:

最近在幫公司優化php專案。一邊優化一邊百度。這個專案存取量挺大的(平均每分鐘請求在80000+)。

用了三臺aws伺服器。兩臺8核16G、一臺4核16G。小的這臺做Nginx並跑少量的php-fpm程序。基本上放上去就掛。存取全是502、504。因為專案是沒有問題的,之前測試跑過了。然後就開始百度找問題。

1、懷疑是nginx的設定存取數或者連線數太小了扛不住,然後就增加nginx的兩個引數。

每個程序允許的最多連線數,理論上每臺nginx伺服器的最大連線數為worker_processes*worker_connections

 worker_connections 5000;
登入後複製

一個nginx程序開啟的最多檔案描述符數目,理論值應該是最多開啟檔案數(ulimit -n)與nginx程序數相除

worker_rlimit_nofile 20000;
登入後複製

php請求的超時時間和快取等

fastcgi_connect_timeout 300;
fastcgi_send_timeout 300;
fastcgi_read_timeout 300;
fastcgi_buffer_size 64k;
fastcgi_buffers 4 64k;
fastcgi_busy_buffers_size 128k;
fastcgi_temp_file_write_size 256k;
登入後複製

nginx設定完了 重新啟動一下。。但是測試了一下 完全沒反應。

2、懷疑是php的設定問題。

確認php-fpm的worker程序是否夠用,如果不夠用就等於沒有開啟一樣

計算開啟worker程序數目:

ps -ef | grep 'php-fpm'|grep -v 'master'|grep -v 'grep' |wc -l
登入後複製

計算正在使用的worker程序,正在處理的請求

netstat -anp | grep 'php-fpm'|grep -v 'LISTENING'|grep -v 'php-fpm.conf'|wc -l
登入後複製

如果上面兩個值接近可以考慮增加worker_connections程序的數量

以及修改修改php-fpm.conf中的php程序數。無論是調大還是調小這幾個引數都不行。。。。絕望了!

修改了php-fpm.conf的紀錄檔級別log_level = debug。在error_log檔案中看到了一下錯誤:

[29-Mar-2014 22:40:10] ERROR: failed to ptrace(PEEKDATA) pid 4276: Input/output error (5)
[29-Mar-2014 22:53:54] ERROR: failed to ptrace(PEEKDATA) pid 4319: Input/output error (5)
[29-Mar-2014 22:56:30] ERROR: failed to ptrace(PEEKDATA) pid 4342: Input/output error (5)
登入後複製

於是,我又開始google這個錯誤。找到一遍文章(http://www.mamicode.com/info-detail-1488604.html)。上面說需要禁用掉記錄的慢紀錄檔;slowlog = /var/log/php-fpm/slow.log;request_slowlog_timeout = 15s。此時,我才知道php也是記錄存取時請求比較慢的紀錄檔。然後開啟慢紀錄檔檔案。發現全是php請求redis的錯誤紀錄檔。。。

找到問題原因了,就是php請求redis資料的時候,應該是請求的連線數太多了。redis連線不上導致的問題。。因為此處的業務比較複雜,所以redis的key是多個欄位拼接的。查詢的時候是用的模糊查詢。所有導致redis的效能下降,後面大量的請求連線不上redis。因為這塊兒連結redis的程式碼是我改的。。於是我又把原來請求mysql的程式碼還原了。。

目前專案正常執行了,每臺伺服器的cpu基本上都快100%了。擔心還會出問題,cpu爆滿,mysql的請求連線抗不住。。。等後面再來優化吧!!!!

推薦學習:《》

以上就是php 高並行報語法錯誤怎麼解決的詳細內容,更多請關注TW511.COM其它相關文章!