Cache/it

From Joomla! Documentation

This page is a translated version of the page Cache and the translation is 33% complete.

Other languages:
Deutsch • ‎English • ‎español • ‎eesti • ‎فارسی • ‎français • ‎हिन्दी • ‎italiano • ‎Nederlands • ‎português


Joomla ha diversi modi di memorizzare le "cose". Ecco una panoramica per amministratori e sviluppatori, cosa, dove e quando.

Per gli amministratori

Come amministratore, Joomla ti offre la possibilità di memorizzare nella cache parti del tuo sito. È possibile scegliere di memorizzare nella cache pagine web intere o solo parti di tali pagine. Questa guida spiega come.

Su una pagina web del sito Joomla ci sono 3 cose che possono essere memorizzate nella cache:

  1. L'intera pagina stessa - la cache della pagina
  2. L'output dal componente Joomla per quella pagina Web, noto come visualizzazione di cache
  3. L'output dei moduli mostrati in quella pagina, noto come modulo del cache

Hai un certo numero di impostazioni della cache che ti permettono di controllare ciò che viene memorizzato nella cache:

  1. Il plugin di sistema "System - Page Cache"
  2. La configurazione globale, la scheda Sistema, Impostazioni cache. Qui l'opzione System Cache può essere impostata su
  3. * OFF - Memorizzazione nella cache disabilitata
  4. * ON - Memorizzazione nella cache conservativa
  5. * ON: caching progressivo
  6. Molti moduli all'interno delle loro opzioni hanno una scheda Avanzate in cui è possibile impostare la memorizzazione nella cache su Usa cache globale o No

Come descritto di seguito, ci sono anche regole per la memorizzazione nella cache che sono implementate all'interno del codice Joomla e su cui non si ha alcun controllo.

È possibile cancellare la cache tramite l'opzione di menu amministratore Sistema / Cancella cache. In generale, puoi pensare a Joomla con 3 livelli di cache, aumentando l'aggressività

  1. Conservazione nella cache conservativa
  2. Memorizzazione nella cache progressiva
  3. Cache delle pagine

Vedremo questi tre in dettaglio qui sotto.

Inoltre, gli sviluppatori di Joomla possono utilizzare le funzionalità di memorizzazione nella cache per archiviare il risultato delle query del database, ad esempio, per aumentare la reattività del sito, ma questo non rientra nell'ambito delle funzionalità dell'amministratore.

Page Caching

Per accenderlo, vai su Estensioni amministratore / Plugin, trova il plugin System - Page Cache e abilitalo. Ciò significa che le pagine del sito verranno ora memorizzate nella cache e, ogni volta che vengono richieste nuovamente, verrà pubblicata la pagina cache, anziché essere generata da Joomla dalle informazioni nel database. La pagina memorizzata nella cache continuerà a essere pubblicata fino alla scadenza, come definito dal parametro Cache Time nelle impostazioni di Global Configuration / System / Cache.

Se stai leggendo questa pagina come un'esercitazione e vuoi testare la memorizzazione nella cache della pagina, allora è meglio impostare le impostazioni della cache della Configurazione globale su

  • Cache Handler - File
  • Percorso della cartella della cache: lasciare vuoto
  • Cache Time - 15 (il valore predefinito di 15 minuti)
  • System Cache - OFF - Memorizzazione nella cache disabilitata

Per verificare il funzionamento della cache delle pagine, vai alla pagina web del sito che mostra un articolo. Dopo aver visualizzato quella pagina dovresti trovare nel file system una directory cache/page</ tt> con un file al suo interno che ha un nome di file come <stringa di cifre esadecimali>-cache-page-<stringa di cifre esadecimali>.php</ tt>. (Joomla deve memorizzare pagine cache separate per URL separati in modo che la seconda stringa di cifre esadecimali sia un hash dell'URL della pagina web del sito, per rendere il nome file univoco per quella pagina).

Then use the administrator functionality to change the text of that article, and redisplay the site webpage. You should find the cached version, not your modified text.

Changing an article (or other Joomla item) does not clear the page cache for the webpage(s) where that article is displayed. To clear the page cache go to administrator System / Clear Cache. Click on the checkbox next to the Cache Group called "page", and press the Delete button. When you redisplay your web page it should now show your amended text.

If your site has a function like a shopping basket then applying page caching will cause problems, as pages have to show what the customer has already selected, rather than displaying a cached page which is common to everyone. However, you can configure the System Page Cache plugin to exclude caching specified Menu Items or specified URLs and URL ranges (in the Advanced tab), so that only truly static pages are cached.

Conservative Caching

With Conservative Caching you can cache the View output from components and the output from those Modules which allow caching. But note that this will work only on pages which are not cached using the Page Cache, as for those pages the whole webpage is cached, and Conservative Caching isn't even considered.

To switch on Conservative Caching:

  1. Go to administrator Global Configuration / System and within Cache Settings set System Cache to ON – Conservative caching
  2. Go to Extensions / Modules and select the modules which you'd like to be cached. If that module permits caching then under the Advanced tab you should be able to set Caching to
  • Use Global – this module will be cached (with the Global option now having been set to Conservative caching)
  • No caching – this module will not be cached.

(Note that the Cache Time in the Global Configuration is in minutes but the Cache Time in the Module settings is in seconds.)

Per verificare che funzioni, vai al tuo sito ' assicurati di essere disconnesso ' e vai a una pagina web che mostra un articolo. Controlla il tuo file system e dovresti trovare una cartella cache / com_content contenente un file cache.

You'll also find other directories such as cache/com_languages (as displaying the page involves loading the current language, and this will be cached as well) and also directories relating to module cache, eg cache/com_modules. These result from the use of cache which developers have coded within the Joomla application.

Se modifichi e salvi l'articolo, quindi aggiorni la pagina del sito, questa volta il sito visualizzerà il testo aggiornato. Questo perché ogni volta che la modifica viene salvata, Joomla svuota la cache per quell'articolo.

Tuttavia, è possibile dimostrare che la cache funziona se si modifica il file della cache nella directory cache / com_content utilizzando un editor di testo di base. Utilizzando l'editor, modifica una lettera all'interno del testo dell'articolo nel file della cache e salva il file. Quindi quando aggiorni la pagina web dovresti vedere l'aggiornamento che hai fatto al file cache.

Come è possibile selezionare quali viste dei componenti vengono memorizzate nella cache e in quali circostanze? Ahimè, non puoi farlo. Ciò è determinato dagli sviluppatori del componente principale di Joomla e codificato nel codice php del componente. E i criteri sono diversi per ciascun componente. Tuttavia, puoi facilmente scoprire quali criteri vengono utilizzati perché per ciascuno dei componenti del sito sono codificati nel file controller.php del sito. Ad esempio, al momento della stesura (versione Joomla 3.9.2) per il componente contatti troviamo in components/com_contact / controller.php

if (JFactory::getApplication()->getUserState('com_contact.contact.data') === null)
{
        $cachable = true;
}

This means that the views associated with contacts will be cachable unless there is session data keyed by com_contact.contact.data – which will be the case if in the user session the user has displayed a contact form (eg on a page pointed to by a menuitem of type Contacts / Single Contact).

The equivalent file for articles components/com_content/controller.php contains:

$cachable = true;
if ($user->get('id') || ($this->input->getMethod() === 'POST' && (($vName === 'category' && $this->input->get('layout') !== 'blog') || $vName === 'archive' )))
{
        $cachable = false;
}

The expression $user->get('id') is true if this is a logged in user, so this means that articles are never cached for logged in users. The subsequent expressions relate to other conditions when the caching is not performed, even if the user is not logged in.

So in this way you can discover the circumstances under which caching is performed, but changing these is not advisable. You can also demonstrate that modules are being cached by using the Joomla Breadcrumbs module, ensuring it's displayed in some module position on the webpage, setting its Caching option and manually editing the cached file in cache/mod_breadcrumbs.

Progressive Caching

Like Conservative Caching, Progressive Caching also caches the output from component views and from modules. The functional difference between the two is that with Progressive Caching all modules are always cached. In this case setting the No caching option for a module has no effect. If the caching storage option is to File then you can find the modules cache file (the output from all modules is stored within the same file) within the cache/com_modules directory.

To switch on progressive caching go to administrator Global Configuration / System and within Cache Settings set System Cache to ON – Progressive caching.

As regards the conditions for caching of Joomla core component views there is no difference between conservative and progressive caching. Despite what you may read on some websites and responses to stack overflow questions, it is not the case that conservative caching relates to when the user is not logged on and progressive caching to when the user is logged on.

Summary

A summary of the caching types is below.

Page Caching

  • Configuration: Built-in Plugin (Extensions -> Plugin Manager -> System - Page Cache)
  • Caches: each whole page of your site
  • Based on: URL
  • More info:
    • Optional browser caching: Also caches on your visitors' browser/computer
    • Only caches pages for guest visitors (not for logged in visitors). Be careful using this plugin if you have an interactive site where you want to server content based on session/cookie information rather than on the plain URL only. Features like a shopping cart will not work.

View Caching

  • Configuration: Global Config->Cache
  • Caches: each view of a component
  • Based on: URL, view, parameters, ...
  • More info: Component developers have to include this in their code to work. Mostly this is not done. The Joomla main content component uses this, but only for guest visitors of your site though this is not obligated for every component.

Module Caching

  • Configuration: Global Config->Cache
  • Caches: each module (individually customized via each module's Advanced Parameters)
  • Based on: the module id, the user's view levels and the Itemid parameter in the HTTP request
  • More info: You must disable it on some modules to avoid problems

Further Caching

If you want to check out other cache systems and possibilities, you might want to check out the third-party extensions around caching.

Caching engines or storages

  • Configuration: Global Config->Cache

Here you can choose which system you want your site to use for all caching. Current options are: APC, Eaccelorator, File, Memcache, Redis, XCache.

APC, for example, also caches your php opcode.

For Developers

The class JCache allows a lot of different sorts and levels of caching. The following sub-classes are made specifically, but you can add your own, or use the main one in many different ways.

Don't forget that the first level of cache encountered, will override any deeper caching. I suppose that too many levels is also counterproductive (to be verified though).

  • JCacheView caches and returns the output of a given view (in MVC). A cache id is automatically generated from the URI, specific view and its specific method, or you can give your own.

This can automatically be done via the base controller's display function. For example in the controller of your component:

class DeliciousController extends JController {
	function display() {
		parent::display(true); //true asks for caching.
	}
}

There are also some urlparams to consider. Check this "joomla stack"

Also, be aware that any updates (such as hits or visit counts) will NOT be updated (unless you add this outside this method and thus any deeper MVC-part.)

  • JCachePage caches and returns the body of the page.
  • JCacheCallback caches and returns the output and results of functions or methods.

If you want to cache queries, this is a good class for it, as illustrated here: Using caching to speed up your code

  • JCacheOutput caches and returns output.

This is rather meant for caching a specific part of php code. It acts like an output buffer, but cached.

References