이 글에서는 코드 예제를 통해 PHP를 사용하여 루프 작업 시간을 제어하는 방법을 소개하겠습니다.
프로그램은 루프에서 실행되지만 루프 실행 중에 타임아웃이 발생하여 프로그램이 종료될 수 있으므로 각 루프 작업에 대한 최대 시간을 제한해야 합니다. 시간이 초과되면 개선 프로세스가 직접 연결 해제되고 다음 수준의 루프 작업이 계속됩니다. Ctrip과 멀티스레딩을 사용하면 이 작업을 완료할 수 있지만 이러한 고급 기술을 이해하지 못할 경우 이 간단한 방법을 대신 사용할 수 있습니다.
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 서버가 사라졌다는 메시지가 표시됩니다!
추천 학습: "PHP 비디오 튜토리얼"
위 내용은 PHP를 사용하여 사이클 시간을 제어하는 방법에 대한 자세한 설명은 무엇입니까? (코드 예)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!