Modifying cache keys in Sitecore

Sitecore ships with some very effective cache mechanisms. One of these mechanisms is the html cache where the output of a rendered control is cached in a table which has a key for each entry. The generated key can vary by different parameters which can be set on the sublayout, xslt, view rendering etc.

The vary by possibilities are inherited from the system base template called caching.

Sublayout Template Hierarchy

This is usually more than sufficient control of the cache but sometimes you can also have other context depending variables which you want the cache to differ by.

To do this there are two approaches, the first one is simply to add custom parameters to the control in code depending on your context variable. This can be a fine approach if it is only one or a couple of controls which you need to control the caching of.

The other approach which in the long run seems more flexible is to override the generation of the cache key so it also reflects your context variable.

Cachekeys are generated differently for the “classic” ASP.NET webforms controls and MVC View Renderings so here I will show how it is done for both cases.

Overriding the Sitecore cachekeys in ASP.NET WebForms

First you need to derive a class from the control type on which you want to override the GetCacheKey method. In this example I am using Sublayout .

Then you will need to override the RenderingType which Sitecore uses for creating the webcontrols to instead instantiate your derived class.

The RenderingType classes acts like factories even though the name does not imply this.

Here I am overriding the SublayoutRenderingType

Finally you need to update the web.config configuration/sitecore/renderingControls to use your new rendering type.

Overriding Sitecore Cachekeys using Sitecore MVC

When using MVC it got even easier to override the cache key.

The cachekey is generated by a processor in the renderRendering pipeline so all you need to do is to override the Sitecore.Mvc.Pipelines.Response.RenderRendering.GenerateCacheKey processor.

And then patch it into the Sitecore.mvc.config instead of the GenerateCacheKey processor:

Another approach could be simply adding a processor after the GenerateCacheKey processor in the renderRendering pipeline and then modify the args.CacheKey as desired.

Modifying the cache in Sitecore

As I have shown in this post it is really simple to modify the cache key identifiers which Sitecore uses as keys for the html cache.

It is a shame though that it is not possible to add new cache vary by variations. These are all “hardcoded” on the system template called Caching.

Of course you could create  your own checkbox “Vary by my domain specific entity” and let the system controls inherit that as well. This is just not nice to do and it risks being overwritten when upgrading Sitecore.

So Sitecore, if you want to make caching control even more flexible then make the Vary by fields dynamic and create a separate pipeline responsible for generating the cache key for both webforms and MVC.

Anders Laub

Anders Laub Christoffersen

Anders has been working with Sitecore for over a decade and has in this time been the lead developer and architect on several large scale enterprise solutions all around the world. Anders has been nominated a Sitecore Technical MVP three years in a row for 2014, 2015 and 2016. Anders is now working as a Sr. Solutions Architect at Sitecore in Copenhagen.

One thought on “Modifying cache keys in Sitecore

  1. Great article!

    I knew how to do this on MVC, but was looking for the ASP .NET version.

    If caching is not enabled on a sublayout the call to base.getCacheKey() will return an empty string for that sublayout. Modifying the cachekey in that case prevents that sublayout from being rendered, thus the key should be returned unmodified…

Leave a Reply

Your email address will not be published. Required fields are marked *

*
*
Website