PHP命令行执行整合pathinfo模拟定时任务实例

命令行模式下,根据传参,调用不同控制器。控制器中根据配置定时执行指定方法

Application.PHP

rush:perl;"> $v) { if($k==0) continue; $_SERVER['PATH_INFO'].="/".$v; } } } //pathinfo处理 public static function pathInfo(){ if(isset($_SERVER['PATH_INFO'])){ $pathinfo=array_filter(explode("/",$_SERVER['PATH_INFO'])); for($i=1;$i<=count($pathinfo);$i++){ $key=isset($pathinfo[$i]) ? $pathinfo[$i] : ''; $value=isset($pathinfo[$i+1]) ? $pathinfo[$i+1] :""; switch ($i) { case 1: $_GET['m']=ucfirst($key); break; case 2: $_GET['c']=ucfirst($key); break; case 3: $_GET['a']=$key; break; default: if($i>3){ if($i%2==0){ $_GET[$key]=$value; } } break; } } } $_GET['m']=!empty($_GET['m']) ? ucfirst($_GET['m']) : 'Index'; $_GET['c']=!empty($_GET['c']) ? ucfirst($_GET['c']) : 'Index'; $_GET['a']=!empty($_GET['a']) ? $_GET['a'] : 'index'; $class="\\Controller\\{$_GET['m']}\\{$_GET['c']}"; $controller=new $class; $controller->$_GET['a'](); } //致命错误回调 public static function shutdownCallback(){ $e=error_get_last(); if(!$e) return; self::errorHandler($e['type'],'Fatal error '.$e['message'],$e['file'],$e['line']); } //错误处理 protected static function myErrorHandler($errno,$errstr,$errfile,$errline){ list($micseconds,$seconds)=explode(" ",microtime()); $micseconds=round($micseconds*1000); $micseconds=strlen($micseconds)==1 ? '0'.$micseconds : $micseconds; if(PHP_sapi_name()=="cli"){ $break="\r\n"; }else{ $break="
"; } $mes="[".date("Y-m-d H:i:s",$seconds).":{$micseconds}] ".$errfile." ".$errline." line ".$errstr.$break; echo $mes; } //注册 public static function register(){ error_reporting(0); set_error_handler(function($errno,$errline){ self::myErrorHandler($errno,$errline); }); register_shutdown_function(function(){ self::shutdownCallback(); }); spl_autoload_register("self::loadClass"); } }

Application::main();

\Controller\Client\Cron.PHP

rush:PHP;"> class Cron{
private $second=0;
private $tasks=array(
array("duration"=>5,"method"=>"doSomething"),array("duration"=>2,"method"=>"doSomething2"),);
public function index(){
while (true) {
sleep(1);
$this->second++;
foreach($this->tasks as $task){
if($this->second%$task['duration']==0){
$this->$task['method']();
}
}
}
}
public function doSomething(){
echo "[".date("Y-m-d H:i:s",time())."] doSomething1 ok!\r\n";
}
public function doSomething2(){
echo "[".date("Y-m-d H:i:s",time())."] doSomething2 ok!\r\n";
}
}

效果

方法doSomething每隔2秒执行一次

方法doSomething2每隔5秒执行一次

现在执行其他方法是同步的,可以再优化成开新线程执行这些方法,就不会阻塞主线程的定时了

以上这篇PHP命令行执行整合pathinfo模拟定时任务实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持编程之家。

相关文章

统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
前言 之前做了微信登录,所以总结一下微信授权登录并获取用户...
FastAdmin是我第一个接触的后台管理系统框架。FastAdmin是一...
之前公司需要一个内部的通讯软件,就叫我做一个。通讯软件嘛...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...