mirror of
https://github.com/Lastorder-DC/rhymix.git
synced 2026-01-05 17:51:40 +09:00
219 lines
5.4 KiB
PHP
219 lines
5.4 KiB
PHP
<?php
|
|
/* Copyright (C) NAVER <http://www.navercorp.com> */
|
|
|
|
/**
|
|
* Cache class for memcache
|
|
*
|
|
* @author NAVER (developer@xpressengine.com)
|
|
*/
|
|
class CacheMemcache extends CacheBase
|
|
{
|
|
|
|
/**
|
|
* Default valid time
|
|
* @var int
|
|
*/
|
|
var $valid_time = 36000;
|
|
|
|
/**
|
|
* instance of Memcahe
|
|
* @var Memcahe
|
|
*/
|
|
var $Memcache;
|
|
|
|
/**
|
|
* Get instance of CacheMemcache
|
|
*
|
|
* @param string $url url of memcache
|
|
* @return CacheMemcache instance of CacheMemcache
|
|
*/
|
|
function getInstance($url)
|
|
{
|
|
if(!$GLOBALS['__CacheMemcache__'])
|
|
{
|
|
$GLOBALS['__CacheMemcache__'] = new CacheMemcache($url);
|
|
}
|
|
return $GLOBALS['__CacheMemcache__'];
|
|
}
|
|
|
|
/**
|
|
* Construct
|
|
*
|
|
* Do not use this directly. You can use getInstance() instead.
|
|
* @param string $url url of memcache
|
|
* @return void
|
|
*/
|
|
function CacheMemcache($url)
|
|
{
|
|
//$config['url'] = array('memcache://localhost:11211');
|
|
$config['url'] = is_array($url) ? $url : array($url);
|
|
$this->Memcache = new Memcache;
|
|
|
|
foreach($config['url'] as $url)
|
|
{
|
|
$info = parse_url($url);
|
|
$this->Memcache->addServer($info['host'], $info['port']);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Return whether support or not support cache
|
|
*
|
|
* @return bool Return true on support or false on not support
|
|
*/
|
|
function isSupport()
|
|
{
|
|
if($GLOBALS['XE_MEMCACHE_SUPPORT'])
|
|
{
|
|
return true;
|
|
}
|
|
if($this->Memcache->set('xe', 'xe', MEMCACHE_COMPRESSED, 1))
|
|
{
|
|
$GLOBALS['XE_MEMCACHE_SUPPORT'] = true;
|
|
}
|
|
else
|
|
{
|
|
$GLOBALS['XE_MEMCACHE_SUPPORT'] = false;
|
|
}
|
|
return $GLOBALS['XE_MEMCACHE_SUPPORT'];
|
|
}
|
|
|
|
/**
|
|
* Get unique key of given key by path of XE
|
|
*
|
|
* @param string $key Cache key
|
|
* @return string Return unique key
|
|
*/
|
|
function getKey($key)
|
|
{
|
|
return md5(_XE_PATH_ . $key);
|
|
}
|
|
|
|
/**
|
|
* Store data at the server
|
|
*
|
|
* CacheMemcache::put() stores an item $buff with $key on the memcached server.
|
|
* Parameter $valid_time is expiration time in seconds. If it's 0, the item never expires
|
|
* (but memcached server doesn't guarantee this item to be stored all the time, it could be delete from the cache to make place for other items).
|
|
*
|
|
* Remember that resource variables (i.e. file and connection descriptors) cannot be stored in the cache,
|
|
* because they can not be adequately represented in serialized state.
|
|
*
|
|
* @param string $key The key that will be associated with the item.
|
|
* @param mixed $buff The variable to store. Strings and integers are stored as is, other types are stored serialized.
|
|
* @param int $valid_time Expiration time of the item.
|
|
* You can also use Unix timestamp or a number of seconds starting from current time, but in the latter case the number of seconds may not exceed 2592000 (30 days).
|
|
* If it's equal to zero, use the default valid time CacheMemcache::valid_time.
|
|
* @return bool Returns true on success or false on failure.
|
|
*/
|
|
function put($key, $buff, $valid_time = 0)
|
|
{
|
|
if($valid_time == 0)
|
|
{
|
|
$valid_time = $this->valid_time;
|
|
}
|
|
|
|
return $this->Memcache->set($this->getKey($key), array($_SERVER['REQUEST_TIME'], $buff), MEMCACHE_COMPRESSED, $valid_time);
|
|
}
|
|
|
|
/**
|
|
* Return whether cache is valid or invalid
|
|
*
|
|
* @param string $key Cache key
|
|
* @param int $modified_time Unix time of data modified.
|
|
* If stored time is older then modified time, the data is invalid.
|
|
* @return bool Return true on valid or false on invalid.
|
|
*/
|
|
function isValid($key, $modified_time = 0)
|
|
{
|
|
$_key = $this->getKey($key);
|
|
|
|
$obj = $this->Memcache->get($_key);
|
|
if(!$obj || !is_array($obj))
|
|
{
|
|
return false;
|
|
}
|
|
unset($obj[1]);
|
|
|
|
if($modified_time > 0 && $modified_time > $obj[0])
|
|
{
|
|
$this->_delete($_key);
|
|
return false;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* Retrieve item from the server
|
|
*
|
|
* CacheMemcache::get() returns previously stored data if an item with such $key exists on the server at this moment.
|
|
*
|
|
* @param string $key The key to fetch
|
|
* @param int $modified_time Unix time of data modified.
|
|
* If stored time is older then modified time, return false.
|
|
* @return false|mixed Return false on failure or older then modified time. Return the string associated with the $key on success.
|
|
*/
|
|
function get($key, $modified_time = 0)
|
|
{
|
|
$_key = $this->getKey($key);
|
|
$obj = $this->Memcache->get($_key);
|
|
if(!$obj || !is_array($obj))
|
|
{
|
|
return false;
|
|
}
|
|
|
|
if($modified_time > 0 && $modified_time > $obj[0])
|
|
{
|
|
$this->_delete($_key);
|
|
return false;
|
|
}
|
|
|
|
unset($obj[0]);
|
|
|
|
return $obj[1];
|
|
}
|
|
|
|
/**
|
|
* Delete item from the server
|
|
*
|
|
* CacheMemcache::delete() deletes an item with tey $key.
|
|
*
|
|
* @param string $key The key associated with the item to delete.
|
|
* @return void
|
|
*/
|
|
function delete($key)
|
|
{
|
|
$_key = $this->getKey($key);
|
|
$this->_delete($_key);
|
|
}
|
|
|
|
/**
|
|
* Delete item from the server(private)
|
|
*
|
|
* @see CacheMemcache::delete()
|
|
* @param string $_key The key associated with the item to delete.
|
|
* @return void
|
|
*/
|
|
function _delete($_key)
|
|
{
|
|
$this->Memcache->delete($_key);
|
|
}
|
|
|
|
/**
|
|
* Flush all existing items at the server
|
|
*
|
|
* CacheMemcache::truncate() immediately invalidates all existing items.
|
|
* CacheMemcache::truncate() doesn't actually free any resources, it only marks all the items as expired,
|
|
* so occupied memory will be overwitten by new items.
|
|
*
|
|
* @return bool Returns true on success or false on failure.
|
|
*/
|
|
function truncate()
|
|
{
|
|
return $this->Memcache->flush();
|
|
}
|
|
|
|
}
|
|
/* End of file CacheMemcache.class.php */
|
|
/* Location: ./classes/cache/CacheMemcache.class.php */
|