Browse Source

Added RedisDebug for profiling redis parts

master
Anton Terekhov 14 years ago
parent
commit
77a62925d8
  1. 45
      redis/RedisDebug.php
  2. 54
      redis/RedisManager.php

45
redis/RedisDebug.php

@ -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);
}
}

54
RedisManager.php → redis/RedisManager.php

@ -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);
}
} }
Loading…
Cancel
Save