如何构建PHP队列系统

时间:2013-01-04 00:07:18

标签: php queue system daemon queuing

我必须构建一个PHP队列系统,并找到了这个brilliant article http://squirrelshaterobots.com/programming/php/building-a-queue-server-in-php-part-1-understanding-the-project 我用它来创建一个PHP队列系统,它很容易设置和使用。

下面是queue.php的代码,从shell运行(puTTy或somesuch)。

<?PHP 

//. set this constant to false if we ever need to debug
//. the application in a terminal.
define('QUEUESERVER_FORK', true);

//////// fork into a background process ////////
if(QUEUESERVER_FORK){    
    $pid = pcntl_fork(); 
    if($pid === -1) die('error: unable to fork.');    
    else if($pid) exit(0);        
    posix_setsid();    
    sleep(1);        
    ob_start();
}

$queue = array();

//////// setup our named pipe ////////
$pipefile = '/tmp/queueserver-input';

if(file_exists($pipefile))    
    if(!unlink($pipefile))         
        die('unable to remove stale file');

umask(0);


if(!posix_mkfifo($pipefile, 0666))    
    die('unable to create named pipe');

$pipe = fopen($pipefile,'r+');

if(!$pipe) die('unable to open the named pipe');

stream_set_blocking($pipe, false);

//////// process the queue ////////
while(1){    

    while($input = trim(fgets($pipe))){        
        stream_set_blocking($pipe, false);        
        $queue[] = $input;    
    }    

    $job = current($queue);    
    $jobkey = key($queue);    

    if($job){        
        echo 'processing job ', $job, PHP_EOL;                
        process($job);                
        next($queue);        
        unset($job, $queue[$jobkey]);            
    }else{        
        echo 'no jobs to do - waiting...', PHP_EOL;        
        stream_set_blocking($pipe, true);    
    }        

    if(QUEUESERVER_FORK) ob_clean();

}

?>

最难的部分是让pcntl功能在我的服务器上运行。

我的问题是“如果服务器必须重新启动,我如何才能自动启动作业?”

<小时/> 正如评论中所述,编辑了断开的链接,并为后人指出了优秀的网络档案。

1 个答案:

答案 0 :(得分:9)

  

我的问题是“如果服务器必须重新启动,我如何才能自动启动作业?”

将其添加到服务器启动时启动的事项列表中。不幸的是,这样做的说明因操作系统和操作系统版本而异。您可能希望使用更多跨平台的东西。我和supervisor有很多运气,你可以在你选择的操作系统的包装回购中找到它。

那就是说,你走的是疯狂的路线。你正在做的事情之前,更好的,由伟大的人做过。查看Gearman工作队列系统和随附的PECL extension。事实上,主管对于让你的Gearman工作人员保持活力非常方便。