i would like to have no ttl on a custom esi block (or a really high one) and trigger a purge when i create a new post / update a post and thus the order of the posts (order by custom numeric field (rating)) changes.
How can i target the esi block and purge it – i tried everything and cant get it to work
thanks for your help
regards
]]>Issue: Admin Bar ESI not always being rendered
Report number: TUBHZGGO
Report date: 10/27/2023 16:30:40
This issue is likely related to ESI behaviour – ESI block disapear after a while and Issue with LiteSpeed Cache ESI Implementation. I noticed this with a custom theme I made that on multiple sites, the admin bar ESI is just no rendered. Sometimes only on specific pages, sometimes all. I have not been able to reproduce this, it only happens on the search page on my personal site. For someone else using my theme, it is every page.
I noticed the issue only recently and since the theme worked for the past four years with LiteSpeed cache just fine, I assume one of the more recent updates caused this. I have no way to tell.
This is where the admin bar should be:
]]>I noticed today that the error log is filling up with LS messages of this form:
ESI buffer empty /login/
ESI buffer empty /
ESI buffer empty /dashboard/
… and so on and so on, repeated for many different pages within moments of each other
What causes this, and what should I do to prevent these “errors”?
]]>Issue : The ESI Block works for a period of time then stop showing.
Implementation:
Our website use ESI Block to un-cache the website main menu. The feature have be implemented according to the API (https://docs.litespeedtech.com/lscache/lscwp/api/#generate-esi-block-url).
To implement this feature an litespeed_esi_load action have been created in the Theme function.php.
This action displays a navigation menu with wp_nav_menu();
<?php
// Litespeed : Load main-menu without caching for "BW_esi_main_menu" block.
// Create ESI loader for litespeed cache plugin.
// Ressource : https://docs.litespeedtech.com/lscache/lscwp/api/#generate-esi-block-url
function BW_litespeed_esi_load(){
do_action( 'litespeed_control_set_nocache' );
$menu_id = BW_conditional_menu();
echo '<!-- function BW_litespeed_esi_load() $menu_id = '. $menu_id .'-->';
wp_nav_menu( array(
'menu' => $menu_id,
'container' => false,
'theme_location' => 'main-menu',
'menu_class' => 'menu',
'fallback_cb' => 'penci_menu_fallback',
) );
}
add_action( 'litespeed_esi_load-BW_esi_main_menu', 'BW_litespeed_esi_load' );
Then the ESI Block is display through a litespeed_esi_url filter in the template file (menu.php) :
<?php
echo '<!-- display menu.php-->';
// Display main-menu no cached by Litespeed cache plugin.
// From the BW_litespeed_esi_load() function.
// Ressources : https://docs.litespeedtech.com/lscache/lscwp/api/#generate-esi-block-url;
echo apply_filters( 'litespeed_esi_url', 'BW_esi_main_menu', 'Show main-menu no cached by Litespeed cache plugin' );
echo '<!-- display end menu.php-->';
This work great and display correctly an un-cached ESI block for the menu, for a time.
(Below screenshot from the 2024-09-26, The ESI block time stamp is good)
But after some time, look like about a day or maybe a bit more, the ESI Block doesn’t show up anymore.
It’s seems the litespeed_esi_url filter is correctly called as we get the LSCWP Comment with the time stamp of the ESI block, but the litespeed_esi_load action do not do this job.
The time stamp of the ESI block is wrong, as it should be the current date.
(Below screenshot from the 2024-09-28. ESI block doesn’t work. The ESI time stamp is wrong):
After purging all caches, the feature works correctly, and the ESI time stamp is good.
(Below screenshot from the 2024-09-28 , after purging Cachse):
Similar issue found on the support forum:
I have look to the forum and find a similar issues marked as resolved: https://www.ads-software.com/support/topic/strange-esi-behaviour-esi-returning-empty-string-and-forcing-caching-policy/
I did not apply the beta patch version as recommended on this issue, as I’m using LightSpeed Cache 6.5.1. The beta patch have been already merged to the last LightSpeed Cache plugin version I’m using.
Bit more info about the settings
I hope, you will have enough detail to have a look at my issue. Let me know if you need more info.
Thx a lot
Report number:?BQPOXCYS
Report date:?09/28/2024 06:03:16
But when ESI is enabled, even with freshly Purged cache (0 page loads, site is private) all of the Crawler page statuses are Hit (Green = Already Cached). Long loading + cache timestamp in page source confirms that page was not cached by crawler before.
When ESI is disabled – crawler works normally with pages going to Miss (Blue = Successfully Crawled).
Report number:?ETKGDAGP
PS. I do see something in logs
Server/Wordpress logs:
First time when visiting page manually: ESI buffer empty /path/
\
Crawler logs (https://justpaste.it/fhffz) : 09/18/24 09:53:21.132 [213.227.132.36:41126 1 KYP] Redis encountered a fatal error: OOM command not allowed when used memory > 'maxmemory'. (code: 0)
Some that consist of hit in Crawler log:
09/18/24 09:53:20.633 [213.227.132.36:41126 1 KYP] [Optm] _parse_js bypassed due to js files excluded [hit] jquery.min.js
09/18/24 09:53:20.633 [213.227.132.36:41126 1 KYP] [Util] external
09/18/24 09:53:20.633 [213.227.132.36:41126 1 KYP] [Optm] _parse_js bypassed due to js files excluded [hit] stats.wp.com
09/18/24 09:53:20.633 [213.227.132.36:41126 1 KYP] [Util] external
09/18/24 09:53:20.634 [213.227.132.36:41126 1 KYP] [Optm] _parse_js bypassed due to js files excluded [hit] gtag
09/18/24 09:53:20.637 [213.227.132.36:41126 1 KYP] [Optm] _parse_js bypassed due to js excluded [hit] gtag
09/18/24 09:53:20.638 [213.227.132.36:41126 1 KYP] [Util] external
09/18/24 09:53:20.638 [213.227.132.36:41126 1 KYP] [Util] external
09/18/24 09:53:20.638 [213.227.132.36:41126 1 KYP] [Optm] _parse_js bypassed due to js files excluded [hit] stats.wp.com
09/18/24 09:53:20.638 [213.227.132.36:41126 1 KYP] [Optm] inline js defer excluded [setting] _stq
09/18/24 09:53:20.638 [213.227.132.36:41126 1 KYP] [Optm] _parse_js bypassed due to js excluded [hit] _stq
Debug log – https://justpaste.it/eebw6
]]>Very frequently, I believe it could be every ~1h (1h was the shortest amount of time I noticed that it loads all pages again) the cache is purged without any actions, scheduled actions or even without a trace in logs.
After enabling logs with advanced debug level, there is nothing related in Debug log and purge log is completely empty (it populates with manual actions, but I’m clearing it before proceeding with test).
– Site is currently in development and there is no traffic (and orders that could somehow triger purge).
– TTLs are default, so for public pages 1 week
– Auto-updated are disabled
– Latest LiteSpeed cache plugin version
This wasn’t a case with WP Fastest Cache, but I would really like to stick with LiteSpeed as it performs much better except this issue.
Any ideas?
function cart_count_shortcode() {
if (class_exists('WooCommerce')) {
$cart_count = WC()->cart->get_cart_contents_count();
if ($cart_count) {
return '' . $cart_count . '';
}
}
return '';
}
add_shortcode('cart_count', 'cart_count_shortcode');
and then in a template I have:
<?php echo do_shortcode('[esi cart_count ttl="1" cache="private"]'); ?>
But I can go onto an incognito window, add something to my woocommerce cart, but the source HTML comes out as:
<a class="square-button green-bg" href="/cart">
<i class="fas fa-shopping-cart"></i>
<!-- lscwp esi-shortcode -->
<!-- Block cached by LiteSpeed Cache 6.4 on 2024-08-14 23:01:44 -->
<!-- lscwp esi-shortcode esi end -->
</a>
So the ttl/private doesn’t really seem to work for me, as that timestamp is yesterday.
Do you know if I’m missing something?
Thanks!
]]>In fact, the shortcode itself is displayed on the site with a space. like this:
echo do_shortcode(‘[esi my_shortcode]’);
when i check frontend i see:
[my_shortcode ]
there is a space after my_shortcode
Lightspeed and all plugins are updated. I have read all the related articles for it.cache and esi are enabled.
The code below also shows the answer of its activation:
<?php
require( './wp-load.php' );
$esi_status = apply_filters( 'litespeed_esi_status', false );
var_dump($esi_status);
]]>I have had ESI enabled for about a week because some plugins included inline javascript with nonce values. I noticed the nonce values were not changing after 24 hours (or so), and it would cause the plugin not to function. Purging all caches would fix the problem, but 24 hours later the problem would happen again.
Enabling ESI appeared to fix the problem. The nonce would regenerate as expected and the plugin worked normally.
Suddenly the inline javascript is returning a console error of Invalid or unexpected token and instead of the nonce value, this comment appears:
<!– Block cached by LiteSpeed Cache 6.1 on 2024-02-09 09:57:11 –>
This appears to happen to all nonce values that were in inline javascript – so it was breaking all instances of plugins using nonce values in inline javascripts.
When disabling ESI things appear to work again – but now the original problem occurs. After 12-24 hours the plugin stops working due to expired/cached nonce.
Another interesting behavior is when JS minification / JS deferred is enabled, there is this error in the JS console: Uncaught ReferenceError: litespeed_var_# is not defined.
The HTML comment is inserted where the nonce should be:
<script>var __litespeed_var_0__="
<!-- Block cached by LiteSpeed Cache 6.1 on 2024-02-09 09:57:11 -->";</script>
This happens anywhere there is inline javascript that includes a nonce value.
<script>var __litespeed_var_0__='
<!-- Block cached by LiteSpeed Cache 6.1 on 2024-02-09 09:57:43 -->',__litespeed_var_1__='
<!-- Block cached by LiteSpeed Cache 6.1 on 2024-02-09 09:57:43 -->',__litespeed_var_2__="
<!-- Block cached by LiteSpeed Cache 6.1 on 2024-02-09 09:57:11 -->";</script>
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
]]>