How would you handle a situation when you want to cache some sublayout that relies on external data(search index, etc.)?
Here’s the example:
- After updating content you click
“Publish” in Sitecore. - HTML cache is automatically cleared after
publishing. - Sublayout is rendered and put into the cache on
first request, but the search index
is not yet updated. - Search index is updated.
- Until the next cache cleanup, sublayout will display the cached (obsolete) date.
Are there any simple ways to fix this issue?
I’ve got only one idea so far – trigger cache cleanup when the index update is over, but it might be complicated for many reasons.
You can cache the sublayout and vary by params, where you define the custom params. Those params can be a unique string from Lucene, e.g the last time it was rebuilt.
E.g.
Note: the Sitecore code has a typo and it’s “VaryByParm” not “VaryByParam”
In C#:
If you can somehow define a method to determine when the index was last rebuilt, you can use that as a parameter to define custom cache instances based on when the index freshness or staleness. You can even tack on additional parameters, like a datasource, etc.