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:
parent
bf37dbf24f
commit
12e9cabfb7
|
@ -191,21 +191,8 @@ class WP_Object_Cache {
|
||||||
foreach ($dogs as $catt)
|
foreach ($dogs as $catt)
|
||||||
$this->cache['category'][$catt->cat_ID] = $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) {
|
function make_group_dir($group, $perms) {
|
||||||
|
|
|
@ -208,6 +208,16 @@ function get_option($setting) {
|
||||||
if ( $pre )
|
if ( $pre )
|
||||||
return $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');
|
$value = wp_cache_get($setting, 'options');
|
||||||
|
|
||||||
if ( false === $value ) {
|
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
|
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;
|
$value = $row->option_value;
|
||||||
wp_cache_set($setting, $value, 'options');
|
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;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// If home is not set use siteurl.
|
// If home is not set use siteurl.
|
||||||
if ( 'home' == $setting && '' == $value )
|
if ( 'home' == $setting && '' == $value )
|
||||||
|
@ -235,6 +248,12 @@ function get_option($setting) {
|
||||||
return apply_filters( 'option_' . $setting, maybe_unserialize($value) );
|
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) {
|
function form_option($option) {
|
||||||
echo attribute_escape(get_option($option));
|
echo attribute_escape(get_option($option));
|
||||||
}
|
}
|
||||||
|
@ -262,9 +281,29 @@ function get_alloptions() {
|
||||||
return apply_filters('all_options', $all_options);
|
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) {
|
function update_option($option_name, $newvalue) {
|
||||||
global $wpdb;
|
global $wpdb;
|
||||||
|
|
||||||
|
wp_protect_special_option($option_name);
|
||||||
|
|
||||||
if ( is_string($newvalue) )
|
if ( is_string($newvalue) )
|
||||||
$newvalue = trim($newvalue);
|
$newvalue = trim($newvalue);
|
||||||
|
|
||||||
|
@ -279,10 +318,22 @@ function update_option($option_name, $newvalue) {
|
||||||
return true;
|
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 = $newvalue;
|
||||||
$newvalue = maybe_serialize($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');
|
wp_cache_set($option_name, $newvalue, 'options');
|
||||||
|
}
|
||||||
|
|
||||||
$newvalue = $wpdb->escape($newvalue);
|
$newvalue = $wpdb->escape($newvalue);
|
||||||
$option_name = $wpdb->escape($option_name);
|
$option_name = $wpdb->escape($option_name);
|
||||||
|
@ -298,13 +349,26 @@ function update_option($option_name, $newvalue) {
|
||||||
function add_option($name, $value = '', $description = '', $autoload = 'yes') {
|
function add_option($name, $value = '', $description = '', $autoload = 'yes') {
|
||||||
global $wpdb;
|
global $wpdb;
|
||||||
|
|
||||||
// Make sure the option doesn't already exist
|
wp_protect_special_option($name);
|
||||||
if ( false !== get_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;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
$value = maybe_serialize($value);
|
$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');
|
wp_cache_set($name, $value, 'options');
|
||||||
|
}
|
||||||
|
|
||||||
$name = $wpdb->escape($name);
|
$name = $wpdb->escape($name);
|
||||||
$value = $wpdb->escape($value);
|
$value = $wpdb->escape($value);
|
||||||
|
@ -316,11 +380,22 @@ function add_option($name, $value = '', $description = '', $autoload = 'yes') {
|
||||||
|
|
||||||
function delete_option($name) {
|
function delete_option($name) {
|
||||||
global $wpdb;
|
global $wpdb;
|
||||||
|
|
||||||
|
wp_protect_special_option($name);
|
||||||
|
|
||||||
// Get the ID, if no ID then return
|
// Get the ID, if no ID then return
|
||||||
$option_id = $wpdb->get_var("SELECT option_id FROM $wpdb->options WHERE option_name = '$name'");
|
$option = $wpdb->get_row("SELECT option_id, autoload FROM $wpdb->options WHERE option_name = '$name'");
|
||||||
if ( !$option_id ) return false;
|
if ( !$option->option_id ) return false;
|
||||||
$wpdb->query("DELETE FROM $wpdb->options WHERE option_name = '$name'");
|
$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');
|
wp_cache_delete($name, 'options');
|
||||||
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -3,6 +3,6 @@
|
||||||
// This holds the version number in a separate file so we can bump it without cluttering the SVN
|
// This holds the version number in a separate file so we can bump it without cluttering the SVN
|
||||||
|
|
||||||
$wp_version = '2.2-bleeding';
|
$wp_version = '2.2-bleeding';
|
||||||
$wp_db_version = 4772;
|
$wp_db_version = 4773;
|
||||||
|
|
||||||
?>
|
?>
|
||||||
|
|
Loading…
Reference in New Issue