mirror of
https://github.com/phpbb/phpbb.git
synced 2025-07-03 00:28:53 +00:00
Introduce XCache and eAccelerator, make some small changes to the abstract, forgot a period in the command for r9537 :(
git-svn-id: file:///svn/phpbb/branches/phpBB-3_0_0@9538 89ea8834-ac86-4346-8a33-228a782c2dd0
This commit is contained in:
parent
2230e32514
commit
0cdad21cb3
3 changed files with 243 additions and 1 deletions
123
phpBB/includes/acm/acm_eaccelerator.php
Normal file
123
phpBB/includes/acm/acm_eaccelerator.php
Normal file
|
@ -0,0 +1,123 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @package acm
|
||||||
|
* @version $Id$
|
||||||
|
* @copyright (c) 2005, 2009 phpBB Group
|
||||||
|
* @license http://opensource.org/licenses/gpl-license.php GNU Public License
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @ignore
|
||||||
|
*/
|
||||||
|
if (!defined('IN_PHPBB'))
|
||||||
|
{
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Include the abstract base
|
||||||
|
if (!class_exists('acm_memory'))
|
||||||
|
{
|
||||||
|
require("${phpbb_root_path}includes/acm/acm_memory.$phpEx");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ACM for eAccelerator
|
||||||
|
* @package acm
|
||||||
|
* @todo Missing locks from destroy() talk with David
|
||||||
|
*/
|
||||||
|
class acm extends acm_memory
|
||||||
|
{
|
||||||
|
var $serialize_header = '#phpbb-serialized#';
|
||||||
|
|
||||||
|
function acm()
|
||||||
|
{
|
||||||
|
// Call the parent constructor
|
||||||
|
parent::acm_memory();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Purge cache data
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
function purge()
|
||||||
|
{
|
||||||
|
foreach (eaccelerator_list_keys() as $var)
|
||||||
|
{
|
||||||
|
// @todo Check why the substr()
|
||||||
|
eaccelerator_rm(substr($var['name'], 1));
|
||||||
|
}
|
||||||
|
|
||||||
|
parent::purge();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Perform cache garbage collection
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
function tidy()
|
||||||
|
{
|
||||||
|
eaccelerator_gc();
|
||||||
|
|
||||||
|
set_config('cache_last_gc', time(), true);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fetch an item from the cache
|
||||||
|
*
|
||||||
|
* @access protected
|
||||||
|
* @param string $var Cache key
|
||||||
|
* @return mixed Cached data
|
||||||
|
*/
|
||||||
|
function _read($var)
|
||||||
|
{
|
||||||
|
$result = eaccelerator_get($var);
|
||||||
|
|
||||||
|
if ($result === null)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Handle serialized objects
|
||||||
|
if (is_string($result) && strpos($result, $this->serialize_header . 'O:') === 0)
|
||||||
|
{
|
||||||
|
$result = unserialize(substr($result, strlen($this->serialize_header)));
|
||||||
|
}
|
||||||
|
|
||||||
|
return $result;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Store data in the cache
|
||||||
|
*
|
||||||
|
* @access protected
|
||||||
|
* @param string $var Cache key
|
||||||
|
* @param mixed $data Data to store
|
||||||
|
* @param int $ttl Time-to-live of cached data
|
||||||
|
* @return bool True if the operation succeeded
|
||||||
|
*/
|
||||||
|
function _write($var, $data, $ttl = 2592000)
|
||||||
|
{
|
||||||
|
// Serialize objects and make them easy to detect
|
||||||
|
$data = (is_object($data)) ? $this->serialize_header . serialize($data) : $data;
|
||||||
|
|
||||||
|
return eaccelerator_put($var, $data, $ttl);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove an item from the cache
|
||||||
|
*
|
||||||
|
* @access protected
|
||||||
|
* @param string $var Cache key
|
||||||
|
* @return bool True if the operation succeeded
|
||||||
|
*/
|
||||||
|
function _delete($var)
|
||||||
|
{
|
||||||
|
return eaccelerator_rm($var);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
|
@ -228,7 +228,7 @@ class acm_memory
|
||||||
{
|
{
|
||||||
if ($var_name[0] == '_')
|
if ($var_name[0] == '_')
|
||||||
{
|
{
|
||||||
return true;
|
return $this->_isset($var_name);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -398,6 +398,19 @@ class acm_memory
|
||||||
|
|
||||||
return @unlink($filename);
|
return @unlink($filename);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check if a cache var exists
|
||||||
|
*
|
||||||
|
* @access protected
|
||||||
|
* @param string $var Cache key
|
||||||
|
* @return bool True if it exists, otherwise false
|
||||||
|
*/
|
||||||
|
function _isset($var)
|
||||||
|
{
|
||||||
|
// Most caches don't need to check
|
||||||
|
return true;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
?>
|
?>
|
106
phpBB/includes/acm/acm_xcache.php
Normal file
106
phpBB/includes/acm/acm_xcache.php
Normal file
|
@ -0,0 +1,106 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @package acm
|
||||||
|
* @version $Id$
|
||||||
|
* @copyright (c) 2005, 2009 phpBB Group
|
||||||
|
* @license http://opensource.org/licenses/gpl-license.php GNU Public License
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @ignore
|
||||||
|
*/
|
||||||
|
if (!defined('IN_PHPBB'))
|
||||||
|
{
|
||||||
|
exit;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Include the abstract base
|
||||||
|
if (!class_exists('acm_memory'))
|
||||||
|
{
|
||||||
|
require("${phpbb_root_path}includes/acm/acm_memory.$phpEx");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* ACM for XCache
|
||||||
|
* @package acm
|
||||||
|
*/
|
||||||
|
class acm extends acm_memory
|
||||||
|
{
|
||||||
|
function acm()
|
||||||
|
{
|
||||||
|
// Call the parent constructor
|
||||||
|
parent::acm_memory();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Purge cache data
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
function purge()
|
||||||
|
{
|
||||||
|
$n = xcache_count(XC_TYPE_VAR);
|
||||||
|
|
||||||
|
for ($i = 0; $i < $n; $i++)
|
||||||
|
{
|
||||||
|
xcache_clear_cache(XC_TYPE_VAR, $i);
|
||||||
|
}
|
||||||
|
|
||||||
|
parent::purge();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fetch an item from the cache
|
||||||
|
*
|
||||||
|
* @access protected
|
||||||
|
* @param string $var Cache key
|
||||||
|
* @return mixed Cached data
|
||||||
|
*/
|
||||||
|
function _read($var)
|
||||||
|
{
|
||||||
|
return xcache_get($var);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Store data in the cache
|
||||||
|
*
|
||||||
|
* @access protected
|
||||||
|
* @param string $var Cache key
|
||||||
|
* @param mixed $data Data to store
|
||||||
|
* @param int $ttl Time-to-live of cached data
|
||||||
|
* @return bool True if the operation succeeded
|
||||||
|
*/
|
||||||
|
function _write($var, $data, $ttl = 2592000)
|
||||||
|
{
|
||||||
|
return xcache_set($var, $data, $ttl);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Remove an item from the cache
|
||||||
|
*
|
||||||
|
* @access protected
|
||||||
|
* @param string $var Cache key
|
||||||
|
* @return bool True if the operation succeeded
|
||||||
|
*/
|
||||||
|
function _delete($var)
|
||||||
|
{
|
||||||
|
return xcache_unset($var);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check if a cache var exists
|
||||||
|
*
|
||||||
|
* @access protected
|
||||||
|
* @param string $var Cache key
|
||||||
|
* @return bool True if it exists, otherwise false
|
||||||
|
*/
|
||||||
|
function _isset($var)
|
||||||
|
{
|
||||||
|
// Most caches don't need to check
|
||||||
|
return xcache_isset($var);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
?>
|
Loading…
Add table
Reference in a new issue