php-resque/lib/Resque.php

198 lines
5.1 KiB
PHP
Raw Normal View History

2010-04-18 13:58:43 +00:00
<?php
2011-03-27 07:42:46 +00:00
require_once dirname(__FILE__) . '/Resque/Event.php';
require_once dirname(__FILE__) . '/Resque/Exception.php';
2010-04-18 13:58:43 +00:00
/**
* Base Resque class.
*
* @package Resque
* @author Chris Boulton <chris.boulton@interspire.com>
* @copyright (c) 2010 Chris Boulton
* @license http://www.opensource.org/licenses/mit-license.php
*/
class Resque
{
const VERSION = '1.0';
2012-08-24 14:51:03 +00:00
const DEFAULT_INTERVAL = 5;
2010-04-18 13:58:43 +00:00
/**
* @var Resque_Redis Instance of Resque_Redis that talks to redis.
*/
public static $redis = null;
/**
* @var mixed Host/port conbination separated by a colon, or a nested
* array of server swith host/port pairs
*/
protected static $redisServer = null;
/**
* @var int ID of Redis database to select.
*/
protected static $redisDatabase = 0;
/**
* @var int PID of current process. Used to detect changes when forking
* and implement "thread" safety to avoid race conditions.
*/
protected static $pid = null;
2010-04-18 13:58:43 +00:00
/**
* Given a host/port combination separated by a colon, set it as
* the redis server that Resque will talk to.
*
2010-08-01 05:03:28 +00:00
* @param mixed $server Host/port combination separated by a colon, or
2012-03-01 04:32:52 +00:00
* a nested array of servers with host/port pairs.
* @param int $database
2010-04-18 13:58:43 +00:00
*/
public static function setBackend($server, $database = 0)
2010-04-18 13:58:43 +00:00
{
self::$redisServer = $server;
self::$redisDatabase = $database;
self::$redis = null;
2010-04-18 13:58:43 +00:00
}
/**
* Return an instance of the Resque_Redis class instantiated for Resque.
*
* @return Resque_Redis Instance of Resque_Redis.
*/
public static function redis()
{
// Detect when the PID of the current process has changed (from a fork, etc)
// and force a reconnect to redis.
$pid = getmypid();
if (self::$pid !== $pid) {
self::$redis = null;
self::$pid = $pid;
}
if(!is_null(self::$redis)) {
return self::$redis;
}
$server = self::$redisServer;
if (empty($server)) {
$server = 'localhost:6379';
}
if(is_array($server)) {
require_once dirname(__FILE__) . '/Resque/RedisCluster.php';
self::$redis = new Resque_RedisCluster($server);
}
else {
if (strpos($server, 'unix:') === false) {
list($host, $port) = explode(':', $server);
}
else {
$host = $server;
$port = null;
}
require_once dirname(__FILE__) . '/Resque/Redis.php';
self::$redis = new Resque_Redis($host, $port);
2010-04-18 13:58:43 +00:00
}
self::$redis->select(self::$redisDatabase);
2010-04-18 13:58:43 +00:00
return self::$redis;
}
/**
* Push a job to the end of a specific queue. If the queue does not
* exist, then create it as well.
*
* @param string $queue The name of the queue to add the job to.
* @param array $item Job description as an array to be JSON encoded.
2010-04-18 13:58:43 +00:00
*/
public static function push($queue, $item)
{
self::redis()->sadd('queues', $queue);
self::redis()->rpush('queue:' . $queue, json_encode($item));
}
/**
* Pop an item off the end of the specified queue, decode it and
* return it.
*
* @param string $queue The name of the queue to fetch an item from.
* @return array Decoded item from the queue.
2010-04-18 13:58:43 +00:00
*/
2012-08-24 14:51:03 +00:00
public static function pop($queue, $interval = null)
2010-04-18 13:58:43 +00:00
{
2012-08-24 14:51:03 +00:00
if($interval == null) {
$item = self::redis()->lpop('queue:' . $queue);
} else {
2012-09-10 08:23:18 +00:00
$item = self::redis()->blpop('queue:' . $queue, $interval ? $interval : Resque::DEFAULT_INTERVAL);
2012-08-24 14:51:03 +00:00
}
2010-04-18 13:58:43 +00:00
if(!$item) {
return;
}
2012-08-24 14:51:03 +00:00
return json_decode($interval == 0 ? $item : $item[1], true);
2010-04-18 13:58:43 +00:00
}
/**
* Return the size (number of pending jobs) of the specified queue.
*
* @param $queue name of the queue to be checked for pending jobs
2012-03-01 04:32:52 +00:00
*
2010-04-18 13:58:43 +00:00
* @return int The size of the queue.
*/
public static function size($queue)
{
return self::redis()->llen('queue:' . $queue);
}
/**
* Create a new job and save it to the specified queue.
*
* @param string $queue The name of the queue to place the job in.
* @param string $class The name of the class that contains the code to execute the job.
* @param array $args Any optional arguments that should be passed when the job is executed.
2012-03-01 04:32:52 +00:00
* @param boolean $trackStatus Set to true to be able to monitor the status of a job.
*
* @return string
2010-04-18 13:58:43 +00:00
*/
public static function enqueue($queue, $class, $args = null, $trackStatus = false)
{
require_once dirname(__FILE__) . '/Resque/Job.php';
2011-03-27 07:42:46 +00:00
$result = Resque_Job::create($queue, $class, $args, $trackStatus);
if ($result) {
Resque_Event::trigger('afterEnqueue', array(
'class' => $class,
'args' => $args,
'queue' => $queue,
2011-03-27 07:42:46 +00:00
));
}
2011-03-27 07:42:46 +00:00
return $result;
2010-04-18 13:58:43 +00:00
}
/**
* Reserve and return the next available job in the specified queue.
*
* @param string $queue Queue to fetch next available job from.
* @return Resque_Job Instance of Resque_Job to be processed, false if none or error.
*/
2012-08-24 14:51:03 +00:00
public static function reserve($queue, $interval = null)
2010-04-18 13:58:43 +00:00
{
require_once dirname(__FILE__) . '/Resque/Job.php';
2012-08-24 14:51:03 +00:00
return Resque_Job::reserve($queue, $interval);
2010-04-18 13:58:43 +00:00
}
/**
* Get an array of all known queues.
*
* @return array Array of queues.
*/
public static function queues()
{
$queues = self::redis()->smembers('queues');
if(!is_array($queues)) {
$queues = array();
}
return $queues;
}
2010-05-27 20:26:37 +00:00
}