php為什麼不支援定時器?

2020-07-16 10:05:37
常見的定時器有兩種:一種週期性定時執行,例如每天的凌晨三點出報表;另一種在指定時間後執行(一次),例如會員登入系統五分鐘後發放每日登入獎勵。兩種情況對應shell中的cron和at命令,與JavaScript中的setInterval和setTimeout函數類似(嚴格來說setInterval是週期性執行,指定時間點執行需要自行處理)。

做web開發的PHP程式設計師對JavaScript中的兩個定時器函數應該都還熟悉,回到PHP層面就有點傻眼:

PHP中有sleep,但是沒有(內建)定時器函數可用。sleep函數勉強可以做到,但會導致進程阻塞,期間不能做其他事(或無響應)。為什麼PHP沒能提供定時器(Timer)這個功能呢?

原因

個人認為,web開發中PHP不能使用定時器的本質原因是可控 常駐記憶體執行環境的缺失。兩個要點:第一常駐記憶體,第二可控。CGI模式下,進程執行完指令碼後直接退出,不能指望其到指定時間執行任務;PHP-FPM模式下,進程(絕大多數)常駐記憶體,但不可控。

不可控的意思是執行PHP的進程不受PHP程式碼影響,進程的入口點和退出時機由額外的程式控制。例如FPM模式下,PHP指令碼中的exit、die函數只中斷指令碼的執行,不會對執行指令碼的進程產生特別的影響(記憶體洩露除外)。PHP開發人員編寫的指令碼是進程的執行體,執行完畢後就從進程的執行上下文中解除安裝出去。這種情況下,執行PHP指令碼的時機仍然由外部驅動,沒有外部請求PHP程式碼就安詳的躺在硬碟上,什麼都不做,也就定時任務。

由於PHP主要面向web開發,PHP這種執行模式穩定可靠,開發效率快。比如省去資源釋放這一步,就避免了開發中很多工作量和坑。想想某些第三方庫程式碼中改時區、字元編碼等還不還原,在常駐記憶體執行環境下幾乎肯定會導致後續請求有問題。但在FPM模式下,這種坑無意中直接趟平,省去許多偵錯時間,為程式設計師保住發際線做出了不小的貢獻。

以上就是php為什麼不支援定時器?的詳細內容,更多請關注TW511.COM其它相關文章!