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.
Varnish headers are appended by Cloud Platform and cannot be removed.
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:
curl -sSLIXGET urlname
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 |
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. |
Other headers
Varnish on Cloud Platform also contains headers that enable caching for some HTTP response codes, in infrastructure where this behavior is necessary. The header is:
X-Acquia-No-301-404-Caching-Enforcement
Your Acquia load balancers cache all HTTP 301
and HTTP 404
responses for a minimum of 15 minutes (configurable with max-age), which can prevent cache stampedes and general performance degradation during high-traffic scenario (such as load tests and DDOS attacks). However, caching behavior may be occasionally undesirable. You can set the response header to bypass this requirement, as shown in the following example:
X-Acquia-No-301-404-Caching-Enforcement: 1
Varnish will not cache the following HTTP responses:
- HTTP status codes greater than or equal to
HTTP 302
with the exception ofHTTP 404
.
For example, Varnish will cache200 OK
responses. - Responses that return an invalid or negative
max-age
value. - HTTP methods other than
GET
andHEAD
.
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.