mirror of https://github.com/gohugoio/hugo
108 lines
3.9 KiB
Markdown
108 lines
3.9 KiB
Markdown
---
|
|
title: Configure the HTTP cache
|
|
linkTitle: HTTP cache
|
|
description: Configure the HTTP cache.
|
|
categories: []
|
|
keywords: []
|
|
---
|
|
|
|
> [!note]
|
|
> This configuration is only relevant when using the [`resources.GetRemote`] function.
|
|
|
|
## Layered caching
|
|
|
|
Hugo employs a layered caching system.
|
|
|
|
```goat {.w-40}
|
|
.-----------.
|
|
| dynacache |
|
|
'-----+-----'
|
|
|
|
|
v
|
|
.----------.
|
|
| HTTP cache |
|
|
'-----+----'
|
|
|
|
|
v
|
|
.----------.
|
|
| file cache |
|
|
'-----+----'
|
|
```
|
|
|
|
Dynacache
|
|
: An in-memory cache employing a Least Recently Used (LRU) eviction policy. Entries are removed from the cache when changes occur, when they match [cache-busting] patterns, or under low-memory conditions.
|
|
|
|
HTTP Cache
|
|
: An HTTP cache for remote resources as specified in [RFC 9111]. Optimal performance is achieved when resources include appropriate HTTP cache headers. The HTTP cache utilizes the file cache for storage and retrieval of cached resources.
|
|
|
|
File cache
|
|
: See [configure file caches].
|
|
|
|
The HTTP cache involves two key aspects: determining which content to cache (the caching process itself) and defining the frequency with which to check for updates (the polling strategy).
|
|
|
|
## HTTP caching
|
|
|
|
The HTTP cache behavior is defined for a configured set of resources. Stale resources will be refreshed from the file cache, even if their configured Time-To-Live (TTL) has not expired. If HTTP caching is disabled for a resource, Hugo will bypass the cache and access the file directly.
|
|
|
|
The default configuration disables everything:
|
|
|
|
{{< code-toggle file=hugo >}}
|
|
[HTTPCache.cache.for]
|
|
excludes = ['**']
|
|
includes = []
|
|
{{< /code-toggle >}}
|
|
|
|
cache.for.excludes
|
|
: (`string`) A list of [glob](g) patterns to exclude from caching.
|
|
|
|
cache.for.includes
|
|
: (`string`) A list of [glob](g) patterns to cache.
|
|
|
|
## HTTP polling
|
|
|
|
Polling is used in watch mode (e.g., `hugo server`) to detect changes in remote resources. Polling can be enabled even if HTTP caching is disabled. Detected changes trigger a rebuild of pages using the affected resource. Polling can be disabled for specific resources, typically those known to be static.
|
|
|
|
The default configuration disables everything:
|
|
|
|
{{< code-toggle file=hugo >}}
|
|
[[HTTPCache.polls]]
|
|
disable = true
|
|
high = '0s'
|
|
low = '0s'
|
|
[HTTPCache.polls.for]
|
|
includes = ['**']
|
|
excludes = []
|
|
{{< /code-toggle >}}
|
|
|
|
polls
|
|
: A slice of polling configurations.
|
|
|
|
polls.disable
|
|
: (`bool`) Whether to disable polling for this configuration.
|
|
|
|
polls.low
|
|
: (`string`) The minimum polling interval expressed as a [duration](g). This is used after a recent change and gradually increases towards `polls.high`.
|
|
|
|
polls.high
|
|
: (`string`) The maximum polling interval expressed as a [duration](g). This is used when the resource is considered stable.
|
|
|
|
polls.for.excludes
|
|
: (`string`) A list of [glob](g) patterns to exclude from polling for this configuration.
|
|
|
|
polls.for.includes
|
|
: (`string`) A list of [glob](g) patterns to include in polling for this configuration.
|
|
|
|
## Behavior
|
|
|
|
Polling and HTTP caching interact as follows:
|
|
|
|
- With polling enabled, rebuilds are triggered only by actual changes, detected via `eTag` changes (Hugo generates an MD5 hash if the server doesn't provide one).
|
|
- If polling is enabled but HTTP caching is disabled, the remote is checked for changes only after the file cache's TTL expires (e.g., a `maxAge` of `10h` with a `1s` polling interval is inefficient).
|
|
- If both polling and HTTP caching are enabled, changes are checked for even before the file cache's TTL expires. Cached `eTag` and `last-modified` values are sent in `if-none-match` and `if-modified-since` headers, respectively, and a cached response is returned on HTTP [304].
|
|
|
|
[`resources.GetRemote`]: /functions/resources/getremote/
|
|
[304]: https://developer.mozilla.org/en-US/docs/Web/HTTP/Status/304
|
|
[cache-busting]: /configuration/build/#cache-busters
|
|
[configure file caches]: /configuration/caches/
|
|
[RFC 9111]: https://datatracker.ietf.org/doc/html/rfc9111
|