您好,登錄后才能下訂單哦!
這篇文章主要講解了“php方法執行時間過長的問題怎么解決”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“php方法執行時間過長的問題怎么解決”吧!
php方法執行時間過長的解決辦法:1、進行Nginx網關請求超時設置;2、進行PHP腳本執行時間上限設置。
本文操作環境:windows7系統、PHP7.1版,DELL G3電腦
如何解決php方法執行時間過長的問題?
解決 PHP 方法執行時間過長導致 502 Bad Gateway
背景
最近遇到一個問題,有一段 PHP 代碼需要涉及到長時間的 IO 操作,而這一段會阻塞請求所在的線程,導致請求超時。
你可能會說,這有啥難的,開個線程異步去做,做好了更新狀態就 OK 了。這真是一個不錯的方案,可惜這一整套代碼都是別人的。如果要修改代碼,業務上會牽一發而動全身,所以我的解決辦法是盡量不修改代碼的情況下,通過配置超時時間來解決這個問題。
解決方案
從以上問題來看,超時主要受到兩個因素的影響:
Nginx 網關請求超時設置
PHP 腳本執行時間上限設置
我們依次進行設置。
Nginx 網關請求超時設置
Nginx 支持超時的設置粒度很細。主要使用的幾個如下:
keepalive_timeout
Nginx 使用 keepalive_timeout 來指定 KeepAlive 的超時時間。指定每個 TCP 連接最多可以保持多長時間。Nginx 的默認值是 75 秒,有些瀏覽器最多只保持 60 秒,所以可以設定為 60 秒。
fastcgi_connect_timeout
與FastCGI服務器建立連接的超時。
fastcgi_send_timeout
設置將請求傳輸到FastCGI服務器的超時。 僅在兩次連續寫入操作之間設置超時,而不是為整個請求的傳輸。 如果FastCGI服務器在此時間內未收到任何內容,則關閉連接。
fastcgi_read_timeout
從FastCGI服務器讀取響應的超時。 僅在兩個連續的讀操作之間設置超時,而不是為整個響應的傳輸。 如果FastCGI服務器在此時間內未傳輸任何內容,則關閉連接。
考慮到一次請求 PHP 腳本的執行和后三個設置比較相關。所以在對應網站的 Nginx 配置文件中添加設置即可。
fastcgi_connect_timeout 600s; fastcgi_send_timeout 600s; fastcgi_read_timeout 600s;
PHP 腳本執行時間上限設置
PHP 腳本的執行時間主要是受兩個配置的影響:
php.ini 中 max_execution_time 和 max_input_time
php.ini 的默認位置在 /usr/local/php/etc/
將 php.ini 配置文件中的這兩個配置項修改為超時時間上限。
max_execution_time = 600 max_input_time = 600 php-fpm.conf 中 request_terminate_timeout php-fpm.conf 的默認位置在 /usr/local/php/etc/ request_terminate_timeout 也設置為超時時間的上限。 request_terminate_timeout = 600
修改完成后重啟 Nginx 和 php-fpm 即可。
service nginx reload /etc/init.d/php-fpm reload
感謝各位的閱讀,以上就是“php方法執行時間過長的問題怎么解決”的內容了,經過本文的學習后,相信大家對php方法執行時間過長的問題怎么解決這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。