您好,登錄后才能下訂單哦!
這篇文章主要講解了“如何利用PHP操控循環時間”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“如何利用PHP操控循環時間”吧!
循環執行某個程序,但循環執行過程中,可能會超時導致程序死掉,因此需要限制每個循環操作的最長時間。如果超時,則直接斷開改進程,并繼續下一層循環操作。攜程,多線程都可以完成該操作,但在沒有了解這些高深技術的時候,可以用這個簡便的方法替代。
TaskAsync.php
namespace TaskAsync; use Workerman\MySQL\Connection; class TaskAsync { /** * 異步任務 * @params $func 要異步執行的主要函數 * @params $func 要異步執行超時后的函數 * @params $maxTime 異步執行超時的時間 單位:秒 s * @params $params 要傳遞給$func的參數 */ public static function asyncTask(callable $func, $params = array(), $maxTime = 0, callable $func2 = null, $params2 = array()){ pcntl_signal(SIGCHLD, SIG_IGN); //安裝監聽信號 $pid = pcntl_fork(); //生成一個線程 if ($pid == -1) { exit();//創建子進程失敗 } else if ($pid == 0) { //邏輯 try { //執行用戶函數 call_user_func_array($func, $params); } finally { //執行完后殺死進程 posix_kill(posix_getpid(), SIGKILL); exit(0);//結束子進程的操作 } } else if ($pid > 0) { $t = time(); while (true) { $nPid= pcntl_wait($s, WNOHANG); if ($nPid > 0) { break; } else if ($nPid < 0) { break; } else if ($maxTime && time() - $t > $maxTime) { //默認超時時間為0 ,即 不限制超時時間 posix_kill($pid, SIGKILL); if (!empty($func2)) { call_user_func_array($func2, $params2); } break; } else { sleep(1);//每秒輪詢檢查 } } } } public static function getMysqlConn() { $dbConfig = require(APP_PATH . '/database.php'); return new Connection($dbConfig['hostname'], $dbConfig['hostport'], $dbConfig['username'], $dbConfig['password'], $dbConfig['database']); } }
index.php
use TaskAsync\TaskAsync; //使用 while(true) { $db = TaskAsync::getMysqlConn(); //數據庫操作 $db->closeConnection(); $data = [] ;//傳入的數據 TaskAsync::asyncTask(array(new Download(),'downLoadExcel'), array($data), 60 * 60 * 10 , function($data){ echo '執行超時' ; }, array($data) ); }
pcntl_fork 之前,不能有數據庫連接操作,所以,如果涉及到數據庫的操作,在每次循環的時候,一定要重新連接數據庫,執行完操作,要記得斷開數據庫連接,否則這樣會提示 MySQL server has gone away !
感謝各位的閱讀,以上就是“如何利用PHP操控循環時間”的內容了,經過本文的學習后,相信大家對如何利用PHP操控循環時間這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。