Source code for file /joomla/cache/storage/memcache.php
Documentation is available at memcache.php
* @version $Id: memcache.php 9764 2007-12-30 07:48:11Z ircmaxell $
* @package Joomla.Framework
* @copyright Copyright (C) 2005 - 2008 Open Source Matters. All rights reserved.
* @license GNU/GPL, see LICENSE.php
* Joomla! is free software. This version may have been modified pursuant
* to the GNU General Public License, and as distributed it includes or
* is derivative of works licensed under the GNU General Public License or
* other free or open source software licenses.
* See COPYRIGHT.php for copyright notices and details.
// Check to ensure this file is within the rest of the framework
* Memcache cache storage handler
* @author Louis Landry <louis.landry@joomla.org>
* @package Joomla.Framework
* Resource for the current memcached connection.
* Use persistent connections
* @param array $options optional parameters
$params =
$config->getValue('config.memcache_settings');
$this->_compress =
(isset
($params['compression'])) ?
$params['compression'] :
0;
$this->_persistent =
(isset
($params['persistent'])) ?
$params['persistent'] :
false;
// This will be an array of loveliness
$this->_servers =
(isset
($params['servers'])) ?
$params['servers'] :
array();
// Create the memcache connection
$this->_db =
new Memcache;
for ($i=
0, $n=
count($this->_servers); $i <
$n; $i++
)
$server =
$this->_servers[$i];
$this->_db->addServer($server['host'], $server['port'], $this->_persistent);
$this->_hash =
$config->getValue('config.secret');
* Get cached data from memcache by id and group
* @param string $id The cache data id
* @param string $group The cache data group
* @param boolean $checkTime True to verify cache time expiration threshold
* @return mixed Boolean false on failure or a cached data string
function get($id, $group, $checkTime)
$cache_id =
$this->_getCacheId($id, $group);
$this->_setExpire($cache_id);
return $this->_db->get($cache_id);
* Store the data to memcache by id and group
* @param string $id The cache data id
* @param string $group The cache data group
* @param string $data The data to store in cache
* @return boolean True on success, false otherwise
function store($id, $group, $data)
$cache_id =
$this->_getCacheId($id, $group);
$this->_db->set($cache_id.
'_expire', time(), 0, 0);
return $this->_db->set($cache_id, $data, $this->_compress, 0);
* Remove a cached data entry by id and group
* @param string $id The cache data id
* @param string $group The cache data group
* @return boolean True on success, false otherwise
$cache_id =
$this->_getCacheId($id, $group);
$this->_db->delete($cache_id.
'_expire');
return $this->_db->delete($cache_id);
* Clean cache for a group given a mode.
* group mode : cleans all cache in the group
* notgroup mode : cleans all cache not in the group
* @param string $group The cache data group
* @param string $mode The mode for cleaning cache [group|notgroup]
* @return boolean True on success, false otherwise
function clean($group, $mode)
* Garbage collect expired cache data
* @return boolean True on success, false otherwise.
* Test to see if the cache storage is available.
* @return boolean True on success, false otherwise.
* Set expire time on each call since memcache sets it on cache creation.
* @param string $key Cache key to expire.
* @param integer $lifetime Lifetime of the data in seconds.
function _setExpire($key)
$lifetime =
$this->_lifetime;
$expire =
$this->_db->get($key.
'_expire');
if ($expire +
$lifetime <
time()) {
$this->_db->delete($key);
$this->_db->delete($key.
'_expire');
$this->_db->replace($key.
'_expire', time());
* Get a cache_id string from an id/group pair
* @param string $id The cache data id
* @param string $group The cache data group
* @return string The cache_id string
function _getCacheId($id, $group)
$name =
md5($this->_application.
'-'.
$id.
'-'.
$this->_hash.
'-'.
$this->_language);
return 'cache_'.
$group.
'-'.
$name;