Added RedisDebug for profiling redis parts
This commit is contained in:
45
redis/RedisDebug.php
Normal file
45
redis/RedisDebug.php
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* @copyright NetMonsters <team@netmonsters.ru>
|
||||||
|
* @link http://netmonsters.ru
|
||||||
|
* @package Majestic
|
||||||
|
* @subpackage Redis
|
||||||
|
* @since 2011-07-29
|
||||||
|
* @version SVN: $Id$
|
||||||
|
* @filesource $URL$
|
||||||
|
*/
|
||||||
|
|
||||||
|
class RedisDebug
|
||||||
|
{
|
||||||
|
private $redis;
|
||||||
|
|
||||||
|
public function __construct($redis)
|
||||||
|
{
|
||||||
|
if (!is_a($redis, 'Redis')) {
|
||||||
|
throw new MJException();
|
||||||
|
}
|
||||||
|
$this->redis = $redis;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function __call($name, $arguments)
|
||||||
|
{
|
||||||
|
$command = $name . '(' . $this->r_implode(', ', $arguments) . ')';
|
||||||
|
$profiler = Profiler::getInstance()->profilerQuery($command);
|
||||||
|
$data = call_user_func_array(array($this->redis, $name), $arguments);
|
||||||
|
$profiler->end();
|
||||||
|
return $data;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function r_implode($glue, $pieces)
|
||||||
|
{
|
||||||
|
$retVal = array();
|
||||||
|
foreach ($pieces as $r_pieces) {
|
||||||
|
if (is_array($r_pieces)) {
|
||||||
|
$retVal[] = '(' . $this->r_implode($glue, $r_pieces) . ')';
|
||||||
|
} else {
|
||||||
|
$retVal[] = $r_pieces;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return implode($glue, $retVal);
|
||||||
|
}
|
||||||
|
}
|
@ -11,20 +11,20 @@
|
|||||||
|
|
||||||
class RedisManager
|
class RedisManager
|
||||||
{
|
{
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Redis connections
|
* Redis connections
|
||||||
*
|
*
|
||||||
* @var array
|
* @var array
|
||||||
*/
|
*/
|
||||||
static protected $connections = array();
|
static protected $connections = array();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Connect to redis
|
* Connect to redis
|
||||||
*
|
*
|
||||||
* @param string $name connection name. If not set 'default' will be used.
|
* @param string $name connection name. If not set 'default' will be used.
|
||||||
* @param array $config Configuration array.
|
* @param array $config Configuration array.
|
||||||
*
|
*
|
||||||
* @return Redis
|
* @return Redis
|
||||||
*/
|
*/
|
||||||
static public function connect($name = 'default', $config = null)
|
static public function connect($name = 'default', $config = null)
|
||||||
@ -33,19 +33,22 @@ class RedisManager
|
|||||||
if (!$config) {
|
if (!$config) {
|
||||||
$config = Config::get('Redis')->$name;
|
$config = Config::get('Redis')->$name;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!is_array($config)) {
|
if (!is_array($config)) {
|
||||||
throw new Exception('Connection parameters must be an array');
|
throw new Exception('Connection parameters must be an array');
|
||||||
}
|
}
|
||||||
|
|
||||||
$host = isset($config['host']) ? $config['host'] : 'localhost';
|
$host = isset($config['host']) ? $config['host'] : 'localhost';
|
||||||
$port = isset($config['port']) ? $config['port'] : 6379;
|
$port = isset($config['port']) ? $config['port'] : 6379;
|
||||||
$database = isset($config['database']) ? $config['database'] : 0;
|
$database = isset($config['database']) ? $config['database'] : 0;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @var Redis
|
* @var Redis
|
||||||
*/
|
*/
|
||||||
$connection = new Redis();
|
$connection = new Redis();
|
||||||
|
if (defined('DEBUG') && DEBUG == true) {
|
||||||
|
$connection = new RedisDebug($connection);
|
||||||
|
}
|
||||||
if (!$connection->connect($host, $port)) {
|
if (!$connection->connect($host, $port)) {
|
||||||
throw new Exception('Failed to connect to Redis server at ' . $host . ':' . $port);
|
throw new Exception('Failed to connect to Redis server at ' . $host . ':' . $port);
|
||||||
}
|
}
|
||||||
@ -58,4 +61,39 @@ class RedisManager
|
|||||||
}
|
}
|
||||||
return self::$connections[$name];
|
return self::$connections[$name];
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class RedisDebug
|
||||||
|
{
|
||||||
|
private $redis;
|
||||||
|
|
||||||
|
public function __construct($redis)
|
||||||
|
{
|
||||||
|
if (!is_a($redis, 'Redis')) {
|
||||||
|
throw new MJException();
|
||||||
|
}
|
||||||
|
$this->redis = $redis;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function __call($name, $arguments)
|
||||||
|
{
|
||||||
|
$command = $name . '(' . $this->r_implode(', ', $arguments) . ')';
|
||||||
|
$profiler = Profiler::getInstance()->profilerQuery($command);
|
||||||
|
$data = call_user_func_array(array($this->redis, $name), $arguments);
|
||||||
|
$profiler->end();
|
||||||
|
return $data;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function r_implode($glue, $pieces)
|
||||||
|
{
|
||||||
|
$retVal = array();
|
||||||
|
foreach ($pieces as $r_pieces) {
|
||||||
|
if (is_array($r_pieces)) {
|
||||||
|
$retVal[] = '(' . $this->r_implode($glue, $r_pieces) . ')';
|
||||||
|
} else {
|
||||||
|
$retVal[] = $r_pieces;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return implode($glue, $retVal);
|
||||||
|
}
|
||||||
}
|
}
|
Reference in New Issue
Block a user