Opened 9 months ago
Last modified 5 weeks ago
#64066 accepted enhancement
Speculative Loading: Change default eagerness from conservative to moderate when caching is detected
| Reported by: |
|
Owned by: |
|
|---|---|---|---|
| Milestone: | Future Release | Priority: | normal |
| Severity: | normal | Version: | 6.8 |
| Component: | General | Keywords: | 2nd-opinion has-patch early has-unit-tests |
| Focuses: | performance, sustainability | Cc: |
Description (last modified by )
This is a follow up to #62503 which introduced Speculative Loading (the Speculation Rules API) to core.
As described in the Speculative Loading in 6.8 dev note:
This default of
prefetchwithconservativeeagerness is used as a reasonable starting point to enable speculative loading at the scale of WordPress. It is in line with the configuration that Cloudflare uses in its speculative loading feature, and it minimizes the chance of any speculative loads without a subsequent navigation to the URL.
The default prefetch and mode in core are set to auto:
For both configuration parameters, the value
autosignifies that WordPress Core will decide on the configuration, which as of today effectively leads to a mode ofprefetchand aneagernessofconservative. Depending on various criteria such as the state of the Speculation Rules API and ecosystem support, the behavior may change in a future WordPress release.
In the Speculation Rules API, the eagerness of conservative means that the browser will only start to prefetch the URL when the user starts to click/tap on a link (i.e. mousedown/pointerdown). This gives the navigation about a 50 millisecond head start versus waiting for the click event to finish. With the eagerness of moderate, however, the browser can start to prefetch the URL after the user has hovered over a link for 200 ms on desktop, or (newly) on mobile when a link is visible in the viewport along with some additional heuristics. See Chrome's Speculation rules eagerness improvements. I did a comparison on the impact that the different eagerness levels have on a WordPress site with a normal TTFB (for a WP site) of 1 second: While conservative shaves off 50 ms from that 1-second TTFB, an eagerness of moderate can reduce the perceived TTFB to zero milliseconds.
Nevertheless, a key reason for being conservative is to minimize the chance of unused speculative loads. This is to guard against the increased server load, while also being a sustainability concern. On many shared hosts, the additional traffic incurred by moderate may overtax their limited CPU resources. Nevertheless, this is also an issue when such a site sees an influx in visitors. In order to deal with such traffic spikes, the go-to solution is to use a page caching solution. In fact, WordPress 6.1 introduced a Site Health test via #56041 which specifically checks for the presence of a page cache.
As an additional safeguard, moderate eagerness can be contingent based on whether a persistent object cache is present, that is, whether wp_using_ext_object_cache() returns true. Note that a Site Health test for persistent object cache was introduced in #56040; it could be updated to note that enabling persistent object cache can increase the eagerness in speculative loading, which can also be noted in the Site Health test for page caching.
As noted in the dev note that the default eagerness “may change in a future WordPress release”, I'm proposing that the Site Health test for page cache could be leveraged as a signal to change the default eagerness from conservative to moderate.
Change History (24)
This ticket was mentioned in PR #10123 on WordPress/wordpress-develop by @westonruter.
9 months ago
#1
- Keywords has-patch added
#2
@
9 months ago
- Description modified (diff)
- Summary changed from Speculative Loading: Change default eagerness from conservative to moderate when page cache is detected to Speculative Loading: Change default eagerness from conservative to moderate when caching is detected
@westonruter commented on PR #10123:
9 months ago
#3
This ticket was mentioned in Slack in #core-performance by westonruter. View the logs.
8 months ago
#5
@
8 months ago
- Milestone changed from Awaiting Review to 6.9
As discussed during our Core Performance chat today: milestoning for 6.9 for visibility, but I realize this may likely need to get punted to Future Release to allow for additional considerations.
#7
@
8 months ago
Here's some plugin code that a host could, for example, drop into an mu-plugin to enable moderate eagerness by default unless a plugin (e.g. Speculative Loading) had set it to be something else:
<?php add_filter( 'wp_speculation_rules_configuration', /** * @param array<string, string>|null|mixed $config Config. * @return array<string, string>|null Filtered config. */ static function ( $config ): ?array { // A plugin turned off Speculative Loading. if ( null === $config ) { return null; } // In case a plugin returned a bad value to a filter. if ( ! is_array( $config ) ) { $config = array(); } // See <https://github.com/WordPress/wordpress-develop/blob/e1008a31dfcf6e9c395fa7f744139d11b2c1d9a7/src/wp-includes/speculative-loading.php#L21-L24>. $config = array_merge( array( 'mode' => 'auto', 'eagerness' => 'auto', ), $config ); // Use a default eagerness of moderate if auto remains after all filters applied. if ( 'auto' === $config['eagerness'] ) { $config['eagerness'] = 'moderate'; } return $config; }, PHP_INT_MAX // Allow other plugins (e.g. Speculative Loading) to easily override. );
#8
@
8 months ago
- Milestone changed from 6.9 to Future Release
Looks like this won't make it for 6.9, but let's discuss.
This ticket was mentioned in Slack in #core-performance by westonruter. View the logs.
6 months ago
This ticket was mentioned in Slack in #core-performance by westonruter. View the logs.
6 months ago
This ticket was mentioned in Slack in #core-performance by westonruter. View the logs.
5 months ago
This ticket was mentioned in Slack in #hosting by westonruter. View the logs.
5 months ago
This ticket was mentioned in Slack in #hosting by crixu. View the logs.
5 months ago
This ticket was mentioned in Slack in #hosting by amykamala. View the logs.
5 months ago
This ticket was mentioned in Slack in #core-performance by westonruter. View the logs.
5 months ago
#17
@
5 months ago
See discussion in core dev chat.
This was also discussed in the bugscrub today.
The feedback I got from @jorbin and @desrosj was:
- There needs to be clear communication to hosting providers and documentation in the field guide.
- Data needs to be gathered on what the expected impact there will be on LCP as well as on the increase in page loads (potentially for wasted speculations).
A couple questions for @gilbertococchi (which I also left in #core-performance Slack):
- I know you have data on LCP passing rates for sites with conservative prefetch versus moderate prefetch. What is the latest relative improvement you've seen? Granted, it would be better to look at a set of sites all on conservative and then only switch to moderate after a month to see what their respective passing rates are. (See Slack thread for replies.)
- Also, is there any Chrome data for what is expected for the rate of wasted/unused speculations? The only way I'm aware of to measure this otherwise would be to look at a site that has very stable monthly traffic, and then flip from conservative to moderate after a month, and then to obtain the difference in the server hits in the access logs. (Although this also may not be reliable, if there is a random bot slamming a site one month but not the next.) (See Slack thread for replies.)
This ticket was mentioned in Slack in #core-performance by westonruter. View the logs.
5 months ago
#19
@
4 months ago
- Keywords early added
- Milestone changed from 7.0 to Future Release
Punting since we're too close to beta1 to land this. We need data to justify. So let's work on gathering that data for the next major release, starting in April.
This ticket was mentioned in PR #11501 on WordPress/wordpress-develop by @pratiknawkar94.
2 months ago
#21
- Keywords has-unit-tests added; needs-unit-tests removed
- In production, when a persistent object cache is in use and Site Health has detected page caching (via
advanced-cache.php/WP_CACHEor caching response headers),wp_get_speculation_rules_configuration()now resolveseagernessautoto moderate instead of conservative. WP_Site_Health::check_for_page_caching()stores its raw detection result in thehealth_check_page_cache_detailtransient (including acaching_response_headerslist) so speculative loading can read it.- Page cache and persistent object cache Site Health descriptions include a short note linking to the Speculative Loading dev note and explaining the moderate vs conservative default.
- PHPUnit coverage:
wpGetSpeculationRulesConfiguration(production/staging/development, object cache, transient shapes) andwpSiteHealth(transient populated, descriptions mention speculative loading).
#22
@
6 weeks ago
Some key Shopify data that @gilbertococchi shared: Faster storefront navigations with moderate speculation rules
The desktop result is the one that stands out. Across the curve, the median gain is -285ms TTFB, -224ms FCP, and -228ms LCP. Median TTFB for a speculated navigation is now close to zero, which means the HTML response often arrives before the buyer even commits to clicking. For roughly 10% of speculated navigations, TTFB is exactly 0: the response is already sitting in the cache when the navigation fires.
Gains for mobile are less, as expected, due to the lack of a link hover heuristic.
As for the increase in pages served due unused speculations:
Prefetching earlier means the browser occasionally fetches a page the buyer never ends up visiting. At the same volume of actual page views, moderate triggers nearly 4x as many speculated requests as conservative on desktop, while on mobile the volume barely moves. In our case, that translated to about a 14% increase in the total number of HTML requests. Those numbers will depend on multiple factors: share of same-site navigations and browser mix, to name a few. The desktop-versus-mobile gap is also wide enough to raise a question: should the API let authors set a different eagerness per device type?
For us, the tradeoff is acceptable from both infrastructure and user perspectives. Still, your mileage may vary.
Trac ticket: https://core.trac.wordpress.org/ticket/64066