The DPL-CMS Drupal sites utilizes a multi-tier caching strategy. HTTP responses are cached by Varnish and Drupal caches its various internal data-structures in a Redis key/value store.
- All inbound requests are passed in to an Ingress Nginx controller which forwards the traffic for the individual sites to their individual Varnish instances.
- Varnish serves up any static or anonymous responses it has cached from its object-store.
- If the request is cache miss the request is passed further on Nginx which serves any requests for static assets.
- If the request is for a dynamic page the request is forwarded to the Drupal- installation hosted by PHP-FPM.
- Drupal bootstraps, and produces the requested response.
- During this process it will either populate or reuse it cache which is stored in Redis.
- Depending on the request Drupal will execute a number of queries against MariaDB and a search index.
Varnish will cache any http responses that fulfills the following requirements
- Is not associated with a php-session (ie, the user is logged in)
- Is a 200
Refer the Lagoon drupal.vcl, docs.lagoon.sh documentation on the Varnish service and the varnish-drupal image for the specifics on the service.
Refer to the caching documentation in dpl-cms for specifics on how DPL-CMS is integrated with Varnish.
DPL-CMS is configured to use Redis as the backend for its core cache as an alternative to the default use of the sql-database as backend. This ensures that a busy site does not overload the shared mariadb-server.