php获取后台Job管理的实现代码
作者:bea
代码如下: <?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!"); } } publ
代码如下:
<?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);
}
}
}
}
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- php smarty 二级分类代码和模版循环例子
- Warning: session_destroy() : Trying to destroy uninitialized sessionq错误
- php中session_unset与session_destroy的区别分析
- 不重新编译PHP为php增加openssl模块的方法
- php的memcached客户端memcached
- PHP模块 Memcached功能多于Memcache
- php模块memcache和memcached区别分析
- sphinx增量索引的一个问题
- 批量获取memcache值并按key的顺序返回的实现代码
- 提高define性能的php扩展hidef的安装和使用
- php学习笔记 php中面向对象三大特性之一[封装性]的应用
- php学习笔记 面向对象的构造与析构方法
- php学习笔记 类的声明与对象实例化
- php学习笔记 PHP面向对象的程序设计
- php学习笔记 数组的常用函数
- PHP中的函数嵌套层数限制分析
- PHP5中新增stdClass 内部保留类
- php中使用Akismet防止垃圾评论的代码
- php中通过虚代理实现延迟加载的实现代码