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

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

代码片段:

Copy to ClipboardLiehuo.Net Codes引用的内容:[www.veryhuo.com]
<?php defined(‘SYSPATH’) OR die(‘No direct access allowed.’);
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);

}
}
}

}

波比源码 – 精品源码模版分享 | www.bobi11.com
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需!
7. 本站源码并不保证全部能正常使用,仅供有技术基础的人学习研究,请谨慎下载
8. 如遇到加密压缩包,请使用WINRAR解压,如遇到无法解压的请联系管理员!

波比源码 » PHP获得job队列、创建执行进程、等待结束
赞助VIP 享更多特权,建议使用 QQ 登录
喜欢我嘛?喜欢就按“ctrl+D”收藏我吧!♡