Browse Source
Add Redis cache implementation, prefer over memcached, tests & config sample
remotes/origin/fix-10825
Add Redis cache implementation, prefer over memcached, tests & config sample
remotes/origin/fix-10825
4 changed files with 139 additions and 2 deletions
-
14config/config.sample.php
-
4lib/private/memcache/factory.php
-
94lib/private/memcache/redis.php
-
29tests/lib/memcache/redis.php
@ -0,0 +1,94 @@ |
|||
<?php |
|||
/** |
|||
* Copyright (c) 2014 Jörn Friedrich Dreyer <jfd@butonic.de> |
|||
* This file is licensed under the Affero General Public License version 3 or |
|||
* later. |
|||
* See the COPYING-README file. |
|||
*/ |
|||
|
|||
namespace OC\Memcache; |
|||
|
|||
class Redis extends Cache { |
|||
|
|||
/** |
|||
* @var \Redis $cache |
|||
*/ |
|||
private static $cache = null; |
|||
|
|||
public function __construct($prefix = '') { |
|||
parent::__construct($prefix); |
|||
if (is_null(self::$cache)) { |
|||
// TODO allow configuring a RedisArray, see https://github.com/nicolasff/phpredis/blob/master/arrays.markdown#redis-arrays
|
|||
self::$cache = new \Redis(); |
|||
$config = \OC::$server->getSystemConfig()->getValue('redis', array()); |
|||
if (isset($config['host'])) { |
|||
$host = $config['host']; |
|||
} else { |
|||
$host = '127.0.0.1'; |
|||
} |
|||
if (isset($config['port'])) { |
|||
$port = $config['port']; |
|||
} else { |
|||
$port = 6379; |
|||
} |
|||
if (isset($config['timeout'])) { |
|||
$timeout = $config['timeout']; |
|||
} else { |
|||
$timeout = 0.0; // unlimited
|
|||
} |
|||
self::$cache->connect( $host, $port, $timeout ); |
|||
} |
|||
} |
|||
|
|||
/** |
|||
* entries in redis get namespaced to prevent collisions between ownCloud instances and users |
|||
*/ |
|||
protected function getNameSpace() { |
|||
return $this->prefix; |
|||
} |
|||
|
|||
public function get($key) { |
|||
$result = self::$cache->get($this->getNamespace() . $key); |
|||
if ($result === false and ! self::$cache->exists($this->getNamespace() . $key)) { |
|||
return null; |
|||
} else { |
|||
return $result; |
|||
} |
|||
} |
|||
|
|||
public function set($key, $value, $ttl = 0) { |
|||
if ($ttl > 0) { |
|||
return self::$cache->setex($this->getNamespace() . $key, $ttl, $value); |
|||
} else { |
|||
return self::$cache->set($this->getNamespace() . $key, $value); |
|||
} |
|||
} |
|||
|
|||
public function hasKey($key) { |
|||
return self::$cache->exists($this->getNamespace() . $key); |
|||
} |
|||
|
|||
public function remove($key) { |
|||
if (self::$cache->delete($this->getNamespace() . $key)) { |
|||
return true; |
|||
} else { |
|||
return false; |
|||
} |
|||
|
|||
} |
|||
|
|||
public function clear($prefix = '') { |
|||
$prefix = $this->getNamespace() . $prefix.'*'; |
|||
$it = null; |
|||
self::$cache->setOption(\Redis::OPT_SCAN, \Redis::SCAN_RETRY); |
|||
while($keys = self::$cache->scan($it, $prefix)) { |
|||
self::$cache->delete($keys); |
|||
} |
|||
return true; |
|||
} |
|||
|
|||
static public function isAvailable() { |
|||
return extension_loaded('redis'); |
|||
} |
|||
} |
|||
|
|||
@ -0,0 +1,29 @@ |
|||
<?php |
|||
|
|||
/** |
|||
* Copyright (c) 2013 Robin Appelman <icewind@owncloud.com> |
|||
* This file is licensed under the Affero General Public License version 3 or |
|||
* later. |
|||
* See the COPYING-README file. |
|||
*/ |
|||
|
|||
namespace Test\Memcache; |
|||
|
|||
class Redis extends Cache { |
|||
static public function setUpBeforeClass() { |
|||
parent::setUpBeforeClass(); |
|||
|
|||
if (!\OC\Memcache\Redis::isAvailable()) { |
|||
self::markTestSkipped('The redis extension is not available.'); |
|||
} |
|||
$instance = new \OC\Memcache\Redis(self::getUniqueID()); |
|||
if ($instance->set(self::getUniqueID(), self::getUniqueID()) === false) { |
|||
self::markTestSkipped('redis server seems to be down.'); |
|||
} |
|||
} |
|||
|
|||
protected function setUp() { |
|||
parent::setUp(); |
|||
$this->instance = new \OC\Memcache\Redis($this->getUniqueID()); |
|||
} |
|||
} |
|||
Write
Preview
Loading…
Cancel
Save
Reference in new issue