Introduce Notoptions and Alloptions caching, so that all options (and previously attempted Notoptions) are read from the cache in one go. Should reduce cache misses to zero or close to it. fixes #3726

git-svn-id: http://svn.automattic.com/wordpress/trunk@4855 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
markjaquith 2007-02-01 08:53:08 +00:00
parent bf37dbf24f
commit 12e9cabfb7
3 changed files with 97 additions and 35 deletions

View File

@ -191,21 +191,8 @@ class WP_Object_Cache {
foreach ($dogs as $catt)
$this->cache['category'][$catt->cat_ID] = $catt;
}
} else
if ('options' == $group) {
$wpdb->hide_errors();
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();
if ( ! $options )
return;
foreach ($options as $option) {
$this->cache['options'][$option->option_name] = $option->option_value;
}
}
}
function make_group_dir($group, $perms) {

View File

@ -208,6 +208,16 @@ function get_option($setting) {
if ( $pre )
return $pre;
// prevent non-existent options from triggering multiple queries
$notoptions = wp_cache_get('notoptions', 'options');
if ( isset($notoptions[$setting]) )
return false;
$alloptions = wp_load_alloptions();
if ( isset($alloptions[$setting]) ) {
$value = $alloptions[$setting];
} else {
$value = wp_cache_get($setting, 'options');
if ( false === $value ) {
@ -220,10 +230,13 @@ function get_option($setting) {
if( is_object( $row) ) { // Has to be get_row instead of get_var because of funkiness with 0, false, null values
$value = $row->option_value;
wp_cache_set($setting, $value, 'options');
} else {
} else { // option does not exist, so we must cache its non-existence
$notoptions[$setting] = true;
wp_cache_set('notoptions', $notoptions, 'options');
return false;
}
}
}
// If home is not set use siteurl.
if ( 'home' == $setting && '' == $value )
@ -235,6 +248,12 @@ function get_option($setting) {
return apply_filters( 'option_' . $setting, maybe_unserialize($value) );
}
function wp_protect_special_option($option) {
$protected = array('alloptions', 'notoptions');
if ( in_array($option, $protected) )
die(sprintf(__('%s is a protected WP option and may not be modified'), wp_specialchars($option)));
}
function form_option($option) {
echo attribute_escape(get_option($option));
}
@ -262,9 +281,29 @@ function get_alloptions() {
return apply_filters('all_options', $all_options);
}
function wp_load_alloptions() {
global $wpdb;
$alloptions = wp_cache_get('alloptions', 'options');
if ( !$alloptions ) {
$wpdb->hide_errors();
if ( !$alloptions_db = $wpdb->get_results("SELECT option_name, option_value FROM $wpdb->options WHERE autoload = 'yes'") )
$alloptions_db = $wpdb->get_results("SELECT option_name, option_value FROM $wpdb->options");
$wpdb->show_errors();
$alloptions = array();
foreach ( (array) $alloptions_db as $o )
$alloptions[$o->option_name] = $o->option_value;
wp_cache_set('alloptions', $alloptions, 'options');
}
return $alloptions;
}
function update_option($option_name, $newvalue) {
global $wpdb;
wp_protect_special_option($option_name);
if ( is_string($newvalue) )
$newvalue = trim($newvalue);
@ -279,10 +318,22 @@ function update_option($option_name, $newvalue) {
return true;
}
$notoptions = wp_cache_get('notoptions', 'options');
if ( isset($notoptions[$option_name]) ) {
unset($notoptions[$option_name]);
wp_cache_set('notoptions', $notoptions, 'options');
}
$_newvalue = $newvalue;
$newvalue = maybe_serialize($newvalue);
$alloptions = wp_load_alloptions();
if ( isset($alloptions[$option_name]) ) {
$alloptions[$options_name] = $newvalue;
wp_cache_set('alloptions', $alloptions, 'options');
} else {
wp_cache_set($option_name, $newvalue, 'options');
}
$newvalue = $wpdb->escape($newvalue);
$option_name = $wpdb->escape($option_name);
@ -298,13 +349,26 @@ function update_option($option_name, $newvalue) {
function add_option($name, $value = '', $description = '', $autoload = 'yes') {
global $wpdb;
// Make sure the option doesn't already exist
if ( false !== get_option($name) )
wp_protect_special_option($name);
// Make sure the option doesn't already exist we can check the cache before we ask for a db query
$notoptions = wp_cache_get('notoptions', 'options');
if ( isset($notoptions[$name]) ) {
unset($notoptions[$name]);
wp_cache_set('notoptions', $notoptions, 'options');
} elseif ( false !== get_option($name) ) {
return;
}
$value = maybe_serialize($value);
if ( 'yes' == $autoload ) {
$alloptions = wp_load_alloptions();
$alloptions[$name] = $value;
wp_cache_set('alloptions', $alloptions, 'options');
} else {
wp_cache_set($name, $value, 'options');
}
$name = $wpdb->escape($name);
$value = $wpdb->escape($value);
@ -316,11 +380,22 @@ function add_option($name, $value = '', $description = '', $autoload = 'yes') {
function delete_option($name) {
global $wpdb;
wp_protect_special_option($name);
// Get the ID, if no ID then return
$option_id = $wpdb->get_var("SELECT option_id FROM $wpdb->options WHERE option_name = '$name'");
if ( !$option_id ) return false;
$option = $wpdb->get_row("SELECT option_id, autoload FROM $wpdb->options WHERE option_name = '$name'");
if ( !$option->option_id ) return false;
$wpdb->query("DELETE FROM $wpdb->options WHERE option_name = '$name'");
if ( 'yes' == $option->autoload ) {
$alloptions = wp_load_alloptions();
if ( isset($alloptions[$name]) ) {
unset($alloptions[$name]);
wp_cache_set('alloptions', $alloptions, 'options');
}
} else {
wp_cache_delete($name, 'options');
}
return true;
}

View File

@ -3,6 +3,6 @@
// This holds the version number in a separate file so we can bump it without cluttering the SVN
$wp_version = '2.2-bleeding';
$wp_db_version = 4772;
$wp_db_version = 4773;
?>