php等待程序时间,PHP获得job队列、创建执行进程、等待结束

Copy to Clipboard

e2bccdbad7bc28f4ef2a8fa52a21e480.gif引用的内容:[www.veryhuo.com]

class Controller_Jobs extends Controller_Base{

public function before(){

parent::before();

if(Request::$protocol != "cli"){

die("Only cli allowed!");

}

}

public function after(){

parent::after();

//do some cleaning tasks

}

private function _execJobCommand($joburi,$paras){

$php_exec = Kohana::config("picsou.php_exec");

$php_index = APPINDEX;

$command_args = array();

$command_args[] = $php_index;

$command_args[] = "--uri=".$joburi;

foreach ($paras as $para => $value){

$command_args[] = "--".$para."=".$value;

}

//var_dump($command_args);exit;

echo "exec commmand:".$php_exec."";

pcntl_exec($php_exec,$command_args);

}

/*

* Running jobs in queues

*/

public function action_run(){

$requestCount = 0;

while(true){

$sql = "select * from job_queue where status='1' and approved='1' order by id";

$jobs = DB::query(Database::SELECT,$sql)->execute()->as_array();

if($jobs){

foreach ($jobs as $job){

$requestCount ++;

//update the jobs status as running

DB::update('job_queue')->set(array('status'=>'2'))

->where('id','=',$job['id'])->execute();

$job_pid = pcntl_fork();

if($job_pid == -1){

die("Could not fork Child");

} else if($job_pid == 0 ){

$this->_execJobCommand($job['job_uri'],json_decode($job['paras'],true));

echo "finish Child";

exit(0);

//run jobs here

} else{

echo "Waiting for job";

ob_flush();

$child_pid = pcntl_waitpid($job_pid,$status, WUNTRACED);

echo "waitpid end:".$status."";

if($status == 0){

//job completed

DB::update('job_queue')->set(array('status'=>'999'))

->where('id','=',$job['id'])->execute();

echo "Child Finished";

ob_flush();

}else{

DB::update('job_queue')->set(array('status'=>'-1'))

->where('id','=',$job['id'])->execute();

echo "Child Failed";

ob_flush();

}

}

}

}

else{

if($requestCount >=10){

echo "Have a rest, I have processed 10 jobs";

exit;

}

//no job to run

//echo "No job";

ob_flush();

sleep(5);

}

}

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值