If you have visited the Global Configuration page on a Joomla 2.5 website, then you might have noticed that there are now 2 types of caching:
- Conservative caching
- Progressive caching
We often get calls from our clients asking us what kind of caching to use – we immediately tell them that they should enable the System – Cache plugin and only use conservative caching and never, ever use progressive caching unless they know that they need it. But, as you might’ve guessed, the conversation doesn’t end here, because, like a “forbidden fruit”, they want to know more why they should avoid progressive caching. In fact, when we tell them not to use the aforementioned type of caching, they are more interested in knowing more about it than conservative caching, which we told them to use.
And so we start by explaining the difference between conservative caching and progressive caching:
Conservative caching is the standard type of caching. Here’s how it works:
- A visitor visits a page on your website.
- Joomla checks if there is a non-expired version of that page in its cache directory.
- If the cached page exists (and it’s not expired), then Joomla will serve it to the visitor – otherwise, a cached version of the page is created, and that cached version will be served to the visitor, and to every other consequent visitor, as long as it’s (by “it” we mean the page) not expired.
The above scenario is typical and is how most developers implement caching.
Progressive caching works the following way:
- A visitor visits a page on your website.
- Joomla checks if a cached version of that page exists for that visitor and it’s not yet expired.
- If that cached page exists, then it’ll be served to the visitor, otherwise, Joomla will create the cached page for that specific visitor and then will serve it to him.
- If another visitor (who has never been on that page) visits that page, then Joomla will not serve the cached page of the previous visitor, instead, it will create a cached version of that page specifically for that user, and then serves it to him.
As you can see, progressive caching only offers a performance improvement if the same visitor visits the same page within the lifetime of the cached version of the page. In most scenarios, progressive caching results in a huge performance hit that is far worse than disabling cache, simply because for nearly every visit, Joomla has to process the request, create the cached version of the page, and then serve the page to the visitor (instead of just processing the request and serving the page in the scenario where cache is disabled). Oh, and don’t forget about all the cache files generated by Joomla – you can only imagine how many of these files you will have in your cache folder if you have a high traffic news website (that has many pages).
Now you might wonder, under which circumstances is progressive caching useful? Well, imagine that you have a video website (similar to youtube). You want to show each visitor customized pages based on his location and/or browser settings and/or plugins installed. So, for every page that the visitors loads, you use this information to generate a customized version of that page and you cache it. If the visitor visits that same page again, then Joomla doesn’t need to redo the work to generate the customized page.
Of course, there are many scenarios under which progressive caching is really useful, but in our opinion, progressive caching should only be considered if the website receives many visitors and if those visitors are mostly repeat visitors. Using it in other cases will cause a significant hit on the website’s performance.
We know that caching in Joomla can be quite daunting – but fear not, we’re here to help! Just contact us if you have problems with your Joomla caching (or if you just need advice). We’re super fast, we’re very helpful and friendly, we know our Joomla, and our prices are very, very affordable!
[…] we looked at the global caching in the global configuration. It was set to Progressive Caching (we’ve warned against using progressive caching before), and the cache handler was set to Alternative PHP Cache (APC, and no, it’s not the famous […]