Flush the cache before installing. fixes #1877

git-svn-id: http://svn.automattic.com/wordpress/trunk@3088 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
ryan 2005-11-14 22:32:03 +00:00
parent 08fea3c335
commit a3a84d2957
2 changed files with 86 additions and 78 deletions

View File

@ -137,6 +137,7 @@ if (empty($admin_email)) {
flush(); flush();
// Set everything up // Set everything up
wp_cache_flush();
make_db_current_silent(); make_db_current_silent();
populate_options(); populate_options();
populate_roles(); populate_roles();
@ -198,6 +199,7 @@ http://wordpress.org/
@wp_mail($admin_email, __('New WordPress Blog'), $message, $message_headers); @wp_mail($admin_email, __('New WordPress Blog'), $message, $message_headers);
wp_cache_flush();
?> ?>
<p><em><?php _e('Finished!'); ?></em></p> <p><em><?php _e('Finished!'); ?></em></p>

View File

@ -19,7 +19,7 @@ function wp_cache_delete($id, $flag = '') {
function wp_cache_flush() { function wp_cache_flush() {
global $wp_object_cache; global $wp_object_cache;
return $wp_object_cache->flush(); return $wp_object_cache->flush();
} }
@ -60,28 +60,28 @@ class WP_Object_Cache {
var $mutex; var $mutex;
var $cache = array (); var $cache = array ();
var $dirty_objects = array (); var $dirty_objects = array ();
var $non_existant_objects = array(); var $non_existant_objects = array ();
var $global_groups = array('users', 'usermeta'); var $global_groups = array ('users', 'usermeta');
var $blog_id; var $blog_id;
var $cold_cache_hits = 0; var $cold_cache_hits = 0;
var $warm_cache_hits = 0; var $warm_cache_hits = 0;
var $cache_misses = 0; var $cache_misses = 0;
function add($id, $data, $group = 'default', $expire = '') { function add($id, $data, $group = 'default', $expire = '') {
if ( empty($group) ) if (empty ($group))
$group = 'default'; $group = 'default';
if ( false !== $this->get($id, $group, false) ) if (false !== $this->get($id, $group, false))
return false; return false;
return $this->set($id, $data, $group, $expire); return $this->set($id, $data, $group, $expire);
} }
function delete($id, $group = 'default', $force = false) { function delete($id, $group = 'default', $force = false) {
if ( empty($group) ) if (empty ($group))
$group = 'default'; $group = 'default';
if ( !$force && false === $this->get($id, $group, false) ) if (!$force && false === $this->get($id, $group, false))
return false; return false;
unset ($this->cache[$group][$id]); unset ($this->cache[$group][$id]);
@ -91,20 +91,24 @@ class WP_Object_Cache {
} }
function flush() { function flush() {
return $this->rm($this->cache_dir . '*'); $this->rm($this->cache_dir.'*');
$this->cache = array ();
$this->dirty_objects = array ();
$this->non_existant_objects = array ();
return true;
} }
function get($id, $group = 'default', $count_hits = true) { function get($id, $group = 'default', $count_hits = true) {
if ( empty($group) ) if (empty ($group))
$group = 'default'; $group = 'default';
if (isset ($this->cache[$group][$id])) { if (isset ($this->cache[$group][$id])) {
if ( $count_hits ) if ($count_hits)
$this->warm_cache_hits += 1; $this->warm_cache_hits += 1;
return $this->cache[$group][$id]; return $this->cache[$group][$id];
} }
if ( isset($this->non_existant_objects[$group][$id]) ) if (isset ($this->non_existant_objects[$group][$id]))
return false; return false;
// If caching is not enabled, we have to fall back to pulling from the DB. // If caching is not enabled, we have to fall back to pulling from the DB.
@ -122,7 +126,7 @@ class WP_Object_Cache {
return false; return false;
} }
$cache_file = $this->cache_dir . $this->get_group_dir($group) . "/" . md5($id . DB_PASSWORD) . '.php'; $cache_file = $this->cache_dir.$this->get_group_dir($group)."/".md5($id.DB_PASSWORD).'.php';
if (!file_exists($cache_file)) { if (!file_exists($cache_file)) {
$this->non_existant_objects[$group][$id] = true; $this->non_existant_objects[$group][$id] = true;
$this->cache_misses += 1; $this->cache_misses += 1;
@ -132,14 +136,14 @@ class WP_Object_Cache {
// If the object has expired, remove it from the cache and return false to force // If the object has expired, remove it from the cache and return false to force
// a refresh. // a refresh.
$now = time(); $now = time();
if ( (filemtime($cache_file) + $this->expiration_time) <= $now ) { if ((filemtime($cache_file) + $this->expiration_time) <= $now) {
$this->cache_misses += 1; $this->cache_misses += 1;
$this->delete($id, $group, true); $this->delete($id, $group, true);
return false; return false;
} }
$this->cache[$group][$id] = unserialize(substr(@ file_get_contents($cache_file), strlen(CACHE_SERIAL_HEADER), -strlen(CACHE_SERIAL_FOOTER))); $this->cache[$group][$id] = unserialize(substr(@ file_get_contents($cache_file), strlen(CACHE_SERIAL_HEADER), -strlen(CACHE_SERIAL_FOOTER)));
if ( false === $this->cache[$group][$id]) if (false === $this->cache[$group][$id])
$this->cache[$group][$id] = ''; $this->cache[$group][$id] = '';
$this->cold_cache_hits += 1; $this->cold_cache_hits += 1;
@ -147,7 +151,7 @@ class WP_Object_Cache {
} }
function get_group_dir($group) { function get_group_dir($group) {
if ( false !== array_search($group, $this->global_groups) ) if (false !== array_search($group, $this->global_groups))
return $group; return $group;
return "{$this->blog_id}/$group"; return "{$this->blog_id}/$group";
@ -172,78 +176,79 @@ class WP_Object_Cache {
$this->cache['category'][$catt->cat_ID]->fullpath = $fullpath; $this->cache['category'][$catt->cat_ID]->fullpath = $fullpath;
} }
} }
} else if ( 'options' == $group ) { } else
$wpdb->hide_errors(); if ('options' == $group) {
if ( !$options = $wpdb->get_results("SELECT option_name, option_value FROM $wpdb->options WHERE autoload = 'yes'") ) { $wpdb->hide_errors();
$options = $wpdb->get_results("SELECT option_name, option_value FROM $wpdb->options"); if (!$options = $wpdb->get_results("SELECT option_name, option_value FROM $wpdb->options WHERE autoload = 'yes'")) {
} $options = $wpdb->get_results("SELECT option_name, option_value FROM $wpdb->options");
$wpdb->show_errors(); }
$wpdb->show_errors();
foreach ($options as $option) { foreach ($options as $option) {
$this->cache['options'][$option->option_name] = $option->option_value; $this->cache['options'][$option->option_name] = $option->option_value;
}
} }
}
} }
function make_group_dir($group, $perms) { function make_group_dir($group, $perms) {
$group_dir = $this->get_group_dir($group); $group_dir = $this->get_group_dir($group);
$make_dir = ''; $make_dir = '';
foreach ( split('/', $group_dir) as $subdir) { foreach (split('/', $group_dir) as $subdir) {
$make_dir .= "$subdir/"; $make_dir .= "$subdir/";
if (!file_exists($this->cache_dir . $make_dir)) { if (!file_exists($this->cache_dir.$make_dir)) {
if (!mkdir($this->cache_dir . $make_dir)) if (!mkdir($this->cache_dir.$make_dir))
break; break;
@ chmod($this->cache_dir . $make_dir, $perms); @ chmod($this->cache_dir.$make_dir, $perms);
} }
if (!file_exists($this->cache_dir . $make_dir . "index.php")) { if (!file_exists($this->cache_dir.$make_dir."index.php")) {
touch($this->cache_dir . $make_dir . "index.php"); touch($this->cache_dir.$make_dir."index.php");
} }
} }
return $this->cache_dir . "$group_dir/"; return $this->cache_dir."$group_dir/";
} }
function rm($fileglob) { function rm($fileglob) {
if (is_file($fileglob)) { if (is_file($fileglob)) {
return @unlink($fileglob); return @ unlink($fileglob);
} else if (is_dir($fileglob)) { } else
$ok = $this->rm("$fileglob/*"); if (is_dir($fileglob)) {
if (! $ok) { $ok = WP_Object_Cache::rm("$fileglob/*");
return false; if (!$ok)
} return false;
return @rmdir($fileglob); return @ rmdir($fileglob);
} else { } else {
$matching = glob($fileglob); $matching = glob($fileglob);
if ($matching === false) if ($matching === false)
return true; return true;
$rcs = array_map(array('WP_Object_Cache', 'rm'), $matching); $rcs = array_map(array ('WP_Object_Cache', 'rm'), $matching);
if (in_array(false, $rcs)) { if (in_array(false, $rcs)) {
return false; return false;
} }
} }
return true; return true;
} }
function replace($id, $data, $group = 'default', $expire = '') { function replace($id, $data, $group = 'default', $expire = '') {
if ( empty($group) ) if (empty ($group))
$group = 'default'; $group = 'default';
if ( false === $this->get($id, $group, false) ) if (false === $this->get($id, $group, false))
return false; return false;
return $this->set($id, $data, $group, $expire); return $this->set($id, $data, $group, $expire);
} }
function set($id, $data, $group = 'default', $expire = '') { function set($id, $data, $group = 'default', $expire = '') {
if ( empty($group) ) if (empty ($group))
$group = 'default'; $group = 'default';
if ( NULL == $data) if (NULL == $data)
$data = ''; $data = '';
$this->cache[$group][$id] = $data; $this->cache[$group][$id] = $data;
unset($this->non_existant_objects[$group][$id]); unset ($this->non_existant_objects[$group][$id]);
$this->dirty_objects[$group][] = $id; $this->dirty_objects[$group][] = $id;
return true; return true;
@ -268,9 +273,9 @@ class WP_Object_Cache {
return; return;
@ chmod($this->cache_dir, $dir_perms); @ chmod($this->cache_dir, $dir_perms);
} }
if (!file_exists($this->cache_dir . "index.php")) { if (!file_exists($this->cache_dir."index.php")) {
touch($this->cache_dir . "index.php"); touch($this->cache_dir."index.php");
} }
// Acquire a write lock. Semaphore preferred. Fallback to flock. // Acquire a write lock. Semaphore preferred. Fallback to flock.
@ -290,22 +295,22 @@ class WP_Object_Cache {
$ids = array_unique($ids); $ids = array_unique($ids);
foreach ($ids as $id) { foreach ($ids as $id) {
$cache_file = $group_dir . md5($id . DB_PASSWORD) . '.php'; $cache_file = $group_dir.md5($id.DB_PASSWORD).'.php';
// Remove the cache file if the key is not set. // Remove the cache file if the key is not set.
if ( ! isset($this->cache[$group][$id]) ) { if (!isset ($this->cache[$group][$id])) {
if ( file_exists($cache_file) ) if (file_exists($cache_file))
unlink($cache_file); unlink($cache_file);
continue; continue;
} }
$temp_file = tempnam($group_dir, 'tmp'); $temp_file = tempnam($group_dir, 'tmp');
$serial = CACHE_SERIAL_HEADER . serialize($this->cache[$group][$id]) . CACHE_SERIAL_FOOTER; $serial = CACHE_SERIAL_HEADER.serialize($this->cache[$group][$id]).CACHE_SERIAL_FOOTER;
$fd = fopen($temp_file, 'w'); $fd = fopen($temp_file, 'w');
fputs($fd, $serial); fputs($fd, $serial);
fclose($fd); fclose($fd);
if (!@rename($temp_file, $cache_file)) { if (!@ rename($temp_file, $cache_file)) {
if (copy ($temp_file, $cache_file)) { if (copy($temp_file, $cache_file)) {
unlink($temp_file); unlink($temp_file);
} }
} }
@ -333,38 +338,39 @@ class WP_Object_Cache {
echo "<pre>"; echo "<pre>";
print_r($cache); print_r($cache);
echo "</pre>"; echo "</pre>";
if ( isset($this->dirty_objects[$group]) ) { if (isset ($this->dirty_objects[$group])) {
echo "<strong>Dirty Objects:</strong>"; echo "<strong>Dirty Objects:</strong>";
echo "<pre>"; echo "<pre>";
print_r(array_unique($this->dirty_objects[$group])); print_r(array_unique($this->dirty_objects[$group]));
echo "</pre>"; echo "</pre>";
echo "</p>"; echo "</p>";
} }
} }
} }
function WP_Object_Cache() { function WP_Object_Cache() {
global $blog_id; global $blog_id;
if ( defined('DISABLE_CACHE') ) if (defined('DISABLE_CACHE'))
return; return;
if ( defined('CACHE_PATH') ) if (defined('CACHE_PATH'))
$this->cache_dir = CACHE_PATH; $this->cache_dir = CACHE_PATH;
else else
$this->cache_dir = ABSPATH.'wp-content/cache/'; $this->cache_dir = ABSPATH.'wp-content/cache/';
if ( is_dir($this->cache_dir) ) { if (is_dir($this->cache_dir)) {
if ( is_writable($this->cache_dir) ) if (is_writable($this->cache_dir))
$this->cache_enabled = true; $this->cache_enabled = true;
} else if (is_writable(ABSPATH.'wp-content')) { } else
$this->cache_enabled = true; if (is_writable(ABSPATH.'wp-content')) {
} $this->cache_enabled = true;
}
if ( defined('CACHE_EXPIRATION_TIME') ) if (defined('CACHE_EXPIRATION_TIME'))
$this->expiration_time = CACHE_EXPIRATION_TIME; $this->expiration_time = CACHE_EXPIRATION_TIME;
$this->blog_id = md5($blog_id); $this->blog_id = md5($blog_id);
} }
} }
?> ?>