Use microtime() instead of incrementors for last_changed to to avoid race conditions with cache evictions.
Props westi fixes #23448 git-svn-id: http://core.svn.wordpress.org/trunk@23401 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
7d2eeb5aed
commit
353ef064ea
|
@ -251,7 +251,7 @@ class WP_Comment_Query {
|
||||||
$key = md5( serialize( compact(array_keys($defaults)) ) );
|
$key = md5( serialize( compact(array_keys($defaults)) ) );
|
||||||
$last_changed = wp_cache_get( 'last_changed', 'comment' );
|
$last_changed = wp_cache_get( 'last_changed', 'comment' );
|
||||||
if ( ! $last_changed ) {
|
if ( ! $last_changed ) {
|
||||||
$last_changed = 1;
|
$last_changed = microtime();
|
||||||
wp_cache_set( 'last_changed', $last_changed, 'comment' );
|
wp_cache_set( 'last_changed', $last_changed, 'comment' );
|
||||||
}
|
}
|
||||||
$cache_key = "get_comments:$key:$last_changed";
|
$cache_key = "get_comments:$key:$last_changed";
|
||||||
|
@ -1292,12 +1292,7 @@ function wp_insert_comment($commentdata) {
|
||||||
$comment = get_comment($id);
|
$comment = get_comment($id);
|
||||||
do_action('wp_insert_comment', $id, $comment);
|
do_action('wp_insert_comment', $id, $comment);
|
||||||
|
|
||||||
if ( function_exists( 'wp_cache_incr' ) ) {
|
wp_cache_set( 'last_changed', microtime(), 'comment' );
|
||||||
wp_cache_incr( 'last_changed', 1, 'comment' );
|
|
||||||
} else {
|
|
||||||
$last_changed = wp_cache_get( 'last_changed', 'comment' );
|
|
||||||
wp_cache_set( 'last_changed', $last_changed + 1, 'comment' );
|
|
||||||
}
|
|
||||||
|
|
||||||
return $id;
|
return $id;
|
||||||
}
|
}
|
||||||
|
@ -2050,12 +2045,7 @@ function clean_comment_cache($ids) {
|
||||||
foreach ( (array) $ids as $id )
|
foreach ( (array) $ids as $id )
|
||||||
wp_cache_delete($id, 'comment');
|
wp_cache_delete($id, 'comment');
|
||||||
|
|
||||||
if ( function_exists( 'wp_cache_incr' ) ) {
|
wp_cache_set( 'last_changed', microtime(), 'comment' );
|
||||||
wp_cache_incr( 'last_changed', 1, 'comment' );
|
|
||||||
} else {
|
|
||||||
$last_changed = wp_cache_get( 'last_changed', 'comment' );
|
|
||||||
wp_cache_set( 'last_changed', $last_changed + 1, 'comment' );
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -919,7 +919,7 @@ function wp_get_archives($args = '') {
|
||||||
|
|
||||||
$last_changed = wp_cache_get( 'last_changed', 'posts' );
|
$last_changed = wp_cache_get( 'last_changed', 'posts' );
|
||||||
if ( ! $last_changed ) {
|
if ( ! $last_changed ) {
|
||||||
$last_changed = 1;
|
$last_changed = microtime();
|
||||||
wp_cache_set( 'last_changed', $last_changed, 'posts' );
|
wp_cache_set( 'last_changed', $last_changed, 'posts' );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -3653,7 +3653,7 @@ function get_pages($args = '') {
|
||||||
$key = md5( serialize( compact(array_keys($defaults)) ) );
|
$key = md5( serialize( compact(array_keys($defaults)) ) );
|
||||||
$last_changed = wp_cache_get( 'last_changed', 'posts' );
|
$last_changed = wp_cache_get( 'last_changed', 'posts' );
|
||||||
if ( ! $last_changed ) {
|
if ( ! $last_changed ) {
|
||||||
$last_changed = 1;
|
$last_changed = microtime();
|
||||||
wp_cache_set( 'last_changed', $last_changed, 'posts' );
|
wp_cache_set( 'last_changed', $last_changed, 'posts' );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -4672,12 +4672,7 @@ function clean_post_cache( $post ) {
|
||||||
do_action( 'clean_page_cache', $post->ID );
|
do_action( 'clean_page_cache', $post->ID );
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( function_exists( 'wp_cache_incr' ) ) {
|
wp_cache_set( 'last_changed', microtime(), 'posts' );
|
||||||
wp_cache_incr( 'last_changed', 1, 'posts' );
|
|
||||||
} else {
|
|
||||||
$last_changed = wp_cache_get( 'last_changed', 'posts' );
|
|
||||||
wp_cache_set( 'last_changed', $last_changed + 1, 'posts' );
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -1242,7 +1242,7 @@ function get_terms($taxonomies, $args = '') {
|
||||||
$key = md5( serialize( compact(array_keys($defaults)) ) . serialize( $taxonomies ) . $filter_key );
|
$key = md5( serialize( compact(array_keys($defaults)) ) . serialize( $taxonomies ) . $filter_key );
|
||||||
$last_changed = wp_cache_get( 'last_changed', 'terms' );
|
$last_changed = wp_cache_get( 'last_changed', 'terms' );
|
||||||
if ( ! $last_changed ) {
|
if ( ! $last_changed ) {
|
||||||
$last_changed = 1;
|
$last_changed = microtime();
|
||||||
wp_cache_set( 'last_changed', $last_changed, 'terms' );
|
wp_cache_set( 'last_changed', $last_changed, 'terms' );
|
||||||
}
|
}
|
||||||
$cache_key = "get_terms:$key:$last_changed";
|
$cache_key = "get_terms:$key:$last_changed";
|
||||||
|
@ -2711,12 +2711,7 @@ function clean_term_cache($ids, $taxonomy = '', $clean_taxonomy = true) {
|
||||||
do_action('clean_term_cache', $ids, $taxonomy);
|
do_action('clean_term_cache', $ids, $taxonomy);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( function_exists( 'wp_cache_incr' ) ) {
|
wp_cache_set( 'last_changed', microtime(), 'terms' );
|
||||||
wp_cache_incr( 'last_changed', 1, 'terms' );
|
|
||||||
} else {
|
|
||||||
$last_changed = wp_cache_get( 'last_changed', 'terms' );
|
|
||||||
wp_cache_set( 'last_changed', $last_changed + 1, 'terms' );
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Loading…
Reference in New Issue