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影片教學》
以上是php 高並發報語法錯誤怎麼解決的詳細內容。更多資訊請關注PHP中文網其他相關文章!

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

在php中,可以使用substr()函数来读取字符串后几个字符,只需要将该函数的第二个参数设置为负值,第三个参数省略即可;语法为“substr(字符串,-n)”,表示读取从字符串结尾处向前数第n个字符开始,直到字符串结尾的全部字符。

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

方法:1、用“str_replace(" ","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\ \;||\xc2\xa0)/","其他字符",$str)”语句。

查找方法:1、用strpos(),语法“strpos("字符串值","查找子串")+1”;2、用stripos(),语法“strpos("字符串值","查找子串")+1”。因为字符串是从0开始计数的,因此两个函数获取的位置需要进行加1处理。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

Atom編輯器mac版下載
最受歡迎的的開源編輯器

Dreamweaver CS6
視覺化網頁開發工具

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器