> php教程 > php手册 > PHP如何获得job队列、创建执行进程、等待结束

PHP如何获得job队列、创建执行进程、等待结束

WBOY
풀어 주다: 2016-06-13 09:28:25
원래의
905명이 탐색했습니다.

PHP如何获得job队列、创建执行进程、等待结束

   一个后台式 Job 管理实例,流程是:从数据库中获得job队列、创建新的进程进行执行、等待job结束。

  代码片段:

  class Controller_Jobs extends Controller_Base{

  public function before(){

  parent::before();

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

  die("Only cli allowed!\n");

  }

  }

  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."\n";

  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\n";

  exit(0);

  //run jobs here

  } else{

  echo "Waiting for job\n";

  ob_flush();

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

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

  if($status == 0){

  //job completed

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

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

  echo "Child Finished\n";

  ob_flush();

  }else{

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

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

  echo "Child Failed\n";

  ob_flush();

  }

  }

  }

  }

  else{

  if($requestCount >=10){

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

  exit;

  }

  //no job to run

  //echo "No job\n";

  ob_flush();

  sleep(5);

  }

  }

  }

  }

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 추천
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿