Cloud Platform uses Varnish® caching to increase an application’s perceived performance for visitors. For more information about Varnish, see Using Varnish. Using developer tools integrated with your browser, you can examine the Varnish caching headers sent with each page and item request to see how Varnish caching is working with your application.
To examine what Varnish is doing (or not doing) on one of the pages in your application, examine the values of the Varnish cache headers for the page.
To view these headers, use one of the development tools available for your web browser to view a served web page’s Varnish headers. Your installed browser may already include a set of development tools that you can use. You can also run the following command from a command prompt:
The following are some of the headers you should see:
| Header | Description |
|---|
Age | The amount of time the served item was in the cache, in seconds. If the age is zero, the item was not served from the Varnish cache. |
Cache-Control | The directives that must be applied by all caching mechanisms, from Varnish to the browser cache. If the field has the value no-cache, must-revalidate, post-check=0 or pre-check=0, this item instructs any upstream proxy layers (such as Acquia load balancers or a CDN) to not cache. This header generally is used when Drupal page caching is disabled. Acquia recommends you verify this value is present on all of your website’s pages. If it is, enable caching, and consider using Acquia Purge for cache invalidation. |
Server | The web infrastructure application (currently nginx) that acts as a load balancer to serve the content. |
Vary | The inbound HTTP request headers that need to be taken into account when caching a single URL. The most common example is Accept-Encoding – a header that browsers usually send to websites to indicate whether they want the returned page compressed using gzip or the deflate compression algorithm. This can prevent serving gzip-compressed pages from cache to older browsers that do not support it. |
Via | The web infrastructure application (currently Varnish) over which the request was sent. |
X-Acquia-Stripped-Query | The query strings that have been stripped from the URL, if any. For more information, see Stripping query strings in Varnish. |
X-AH-App-Trace | A response header added when a request is forwarded to PHP-FPM. If PHP-FPM was not needed to serve this request, this header is not added. |
X-AH-Environment | The Acquia environment that provides the page response. Usually prod, but could also include values such as dev or stage. |
X-Cache | Either HIT or MISS depending on whether or not the item was served from the Varnish cache. |
X-Cache-Hits | The number of times this object has been served from cache. Higher numbers indicate that this URL has received more visitors. |
X-Drupal-Cache | Similar to X-Cache, this header indicates the outcome of Drupal’s page cache with HIT or MISS values. A MISS value is not unusual here. For more information about Drupal cache MISS, see Varnish cache HITS and Drupal cache MISS. |
X-Forwarded-For | The originating IP address for a request. |
X-Generator | The software used to create the page. On Cloud Platform, this says Drupal along with the version number of Drupal core. |
X-Geo-Country | The two-letter ISO-3166–1 alpha-2 country code. Available only for Cloud Platform Enterprise and Site Factory subscriptions with dedicated load balancers. For more information, see Using GeoIP information. |
X-Request-ID | The request ID for a given request. For more information, see Using HTTP request IDs. |
X-Static-Assets | Certain non-HTML static assets have cookie headers removed, and receive the HTTP request header X-Static-Asset: True. For more information, see Stripping cookies from static files. |
X-UA-FCF | Either allow or deny depending on whether or not the user has followed a link from Google, Facebook, or LinkedIn. To use the value of this header to construct a paywall or registration wall, see First Click Free support in Varnish. |
X-Acquia-No-301-404-Caching-Enforcement
X-Acquia-No-301-404-Caching-Enforcement: 1
Caching HTTP HEAD responses¶
As REST and HEAD requests have become more popular, the need for these requests to be cacheable has increased. Any code responding to HTTP HEAD requests can now set a Cache-Control response header that Varnish will respect.
For more information about HEAD requests, see HEAD method on Apache.org.