您好,登錄后才能下訂單哦!
這篇文章主要介紹了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方法執行時間過長怎么辦”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。