站长资讯网
最全最丰富的资讯网站

PHP如何控制循环操作的时间

本篇文章给大家介绍一下PHP控制循环操作的时间的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

PHP如何控制循环操作的时间

循环执行某个程序,但循环执行过程中,可能会超时导致程序死掉,因此需要限制每个循环操作的最长时间。如果超时,则直接断开改进程,并继续下一层循环操作。携程,多线程都可以完成该操作,但在没有了解这些高深技术的时候,可以用这个简便的方法替代。

TaskAsync.php

namespace TaskAsync; use WorkermanMySQLConnection; 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 TaskAsyncTaskAsync; //使用 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视频教程

赞(0)
分享到: 更多 (0)
网站地图   沪ICP备18035694号-2    沪公网安备31011702889846号