Make WordPress Core

Changeset 55155


Ignore:
Timestamp:
01/27/2023 10:12:37 PM (21 months ago)
Author:
flixos90
Message:

Editor: Use a non-persistent object cache in wp_get_global_settings().

This changeset is part of a greater effort to enhance the caching strategy for theme.json based data. Similar to [55138] and [55148], the cache is currently ignored when WP_DEBUG is on to avoid interrupting the theme developer's workflow.

This addition of a non-persistent cache results in a significant performance improvement for the overall load time of WordPress, with the Server-Timing load metric being ~8% faster and Time to First Byte being 25+% faster than before.

Props oandregal, spacedmonkey, hellofromtonya, flixos90, azaozz, aristath.
Fixes #57502.

File:
1 edited

Legend:

Unmodified
Added
Removed
  • trunk/src/wp-includes/global-styles-and-settings.php

    r55148 r55155  
    2626function wp_get_global_settings( $path = array(), $context = array() ) {
    2727    if ( ! empty( $context['block_name'] ) ) {
    28         $path = array_merge( array( 'blocks', $context['block_name'] ), $path );
    29     }
    30 
     28        $new_path = array( 'blocks', $context['block_name'] );
     29        foreach ( $path as $subpath ) {
     30            $new_path[] = $subpath;
     31        }
     32        $path = $new_path;
     33    }
     34
     35    /*
     36     * This is the default value when no origin is provided or when it is 'all'.
     37     *
     38     * The $origin is used as part of the cache key. Changes here need to account
     39     * for clearing the cache appropriately.
     40     */
    3141    $origin = 'custom';
    32     if ( isset( $context['origin'] ) && 'base' === $context['origin'] ) {
     42    if (
     43        ! wp_theme_has_theme_json() ||
     44        ( isset( $context['origin'] ) && 'base' === $context['origin'] )
     45    ) {
    3346        $origin = 'theme';
    3447    }
    3548
    36     $settings = WP_Theme_JSON_Resolver::get_merged_data( $origin )->get_settings();
     49    /*
     50     * By using the 'theme_json' group, this data is marked to be non-persistent across requests.
     51     * See `wp_cache_add_non_persistent_groups` in src/wp-includes/load.php and other places.
     52     *
     53     * The rationale for this is to make sure derived data from theme.json
     54     * is always fresh from the potential modifications done via hooks
     55     * that can use dynamic data (modify the stylesheet depending on some option,
     56     * settings depending on user permissions, etc.).
     57     * See some of the existing hooks to modify theme.json behaviour:
     58     * https://make.wordpress.org/core/2022/10/10/filters-for-theme-json-data/
     59     *
     60     * A different alternative considered was to invalidate the cache upon certain
     61     * events such as options add/update/delete, user meta, etc.
     62     * It was judged not enough, hence this approach.
     63     * See https://github.com/WordPress/gutenberg/pull/45372
     64     */
     65    $cache_group = 'theme_json';
     66    $cache_key   = 'wp_get_global_settings_' . $origin;
     67
     68    /*
     69     * Ignore cache when `WP_DEBUG` is enabled, so it doesn't interfere with the theme
     70     * developer's workflow.
     71     *
     72     * @todo Replace `WP_DEBUG` once an "in development mode" check is available in Core.
     73     */
     74    $can_use_cached = ! WP_DEBUG;
     75
     76    $settings = false;
     77    if ( $can_use_cached ) {
     78        $settings = wp_cache_get( $cache_key, $cache_group );
     79    }
     80
     81    if ( false === $settings ) {
     82        $settings = WP_Theme_JSON_Resolver::get_merged_data( $origin )->get_settings();
     83        if ( $can_use_cached ) {
     84            wp_cache_set( $cache_key, $settings, $cache_group );
     85        }
     86    }
    3787
    3888    return _wp_array_get( $settings, $path, $settings );
     
    318368function wp_clean_theme_json_cache() {
    319369    wp_cache_delete( 'wp_get_global_stylesheet', 'theme_json' );
     370    wp_cache_delete( 'wp_get_global_settings_custom', 'theme_json' );
     371    wp_cache_delete( 'wp_get_global_settings_theme', 'theme_json' );
    320372    WP_Theme_JSON_Resolver::clean_cached_data();
    321373}
Note: See TracChangeset for help on using the changeset viewer.