GuideReference
Guide
  • Property Manager name: Caching
  • Behavior version: The v2024-05-31 rule format supports the caching behavior v1.12.
  • Rule format status: GA, stable
  • Access: Read/Write
  • Allowed in includes: Yes

Control content caching on edge servers: whether or not to cache, whether to honor the origin's caching headers, and for how long to cache. Note that any NO_​STORE or BYPASS_​CACHE HTTP headers set on the origin's content override this behavior. For more details on how caching works in Property Manager, see the Learn about caching section in the guide.

OptionTypeDescriptionRequires
behaviorenum

Specify the caching option.

{"displayType":"enum","options":["MAX_AGE","NO_STORE","BYPASS_CACHE","CACHE_CONTROL_AND_EXPIRES","CACHE_CONTROL","EXPIRES"],"tag":"select"}
MAX_​AGE

Honor the origin's MAX_​AGE header.

NO_​STORE

Clears the cache and serves from the origin.

BYPASS_​CACHE

Retains the cache but serves from the origin.

CACHE_​CONTROL_​AND_​EXPIRES

Honor the origin's CACHE_​CONTROL or EXPIRES header, whichever comes last. This adds support for the s-maxage response directive specified in RFC 7234. Use this alternative value to instruct a downstream CDN how long to cache content.

CACHE_​CONTROL

Honor the origin's CACHE_​CONTROL header. This adds support for the s-maxage response directive specified in RFC 7234. Use this alternative value to instruct a downstream CDN how long to cache content.

EXPIRES

Honor the origin's EXPIRES header.

must_​revalidateboolean

Determines what to do once the cached content has expired, by which time the Akamai platform should have re-fetched and validated content from the origin. If enabled, only allows the re-fetched content to be served. If disabled, may serve stale content if the origin is unavailable.

behavior is either: CACHE_​CONTROL_​AND_​EXPIRES, CACHE_​CONTROL, EXPIRES, MAX_​AGE
{"displayType":"boolean","tag":"input","type":"checkbox"}
{"if":{"attribute":"behavior","op":"in","value":["CACHE_CONTROL_AND_EXPIRES","CACHE_CONTROL","EXPIRES","MAX_AGE"]}}
ttlstring (duration)

The maximum time content may remain cached. Setting the value to 0 is the same as setting a no-cache header, which forces content to revalidate.

behavior is MAX_​AGE
{"displayType":"string","tag":"input","type":"text"}
{"if":{"attribute":"behavior","op":"eq","value":"MAX_AGE"}}
default_​ttlstring (duration)

Set the MAX_​AGE header for the cached content.

behavior is either: CACHE_​CONTROL_​AND_​EXPIRES, CACHE_​CONTROL, EXPIRES
{"displayType":"string","tag":"input","type":"text"}
{"if":{"attribute":"behavior","op":"in","value":["CACHE_CONTROL_AND_EXPIRES","CACHE_CONTROL","EXPIRES"]}}
enhanced_​rfc_​supportboolean

This enables honoring particular Cache-Control header directives from the origin. Supports all official RFC 7234 directives except for no-transform.

behavior is either: CACHE_​CONTROL, CACHE_​CONTROL_​AND_​EXPIRES
{"displayType":"boolean","tag":"input","type":"checkbox"}
{"if":{"op":"and","params":[{"attribute":"behavior","op":"in","value":["CACHE_CONTROL","CACHE_CONTROL_AND_EXPIRES"]},{"attribute":"productName","op":"neq","scope":"global","value":"Wholesale_Delivery"},{"attribute":"product.name","op":"neq","scope":"global","value":"Wholesale_Delivery"}]}}
honor_​no_​storeboolean

Instructs edge servers not to cache the response when the origin response includes the no-store directive.

enhanced_​rfc_​support is true
{"displayType":"boolean","tag":"input","type":"checkbox"}
{"if":{"attribute":"enhancedRfcSupport","op":"eq","value":true}}
honor_​privateboolean

Instructs edge servers not to cache the response when the origin response includes the private directive.

behavior is either: CACHE_​CONTROL, CACHE_​CONTROL_​AND_​EXPIRES
{"displayType":"boolean","tag":"input","type":"checkbox"}
{"if":{"attribute":"behavior","op":"in","value":["CACHE_CONTROL","CACHE_CONTROL_AND_EXPIRES"]}}
honor_​no_​cacheboolean

With the no-cache directive present in the response, this instructs edge servers to validate or refetch the response for each request. Effectively, set the time to live ttl to zero seconds.

enhanced_​rfc_​support is true
{"displayType":"boolean","tag":"input","type":"checkbox"}
{"if":{"attribute":"enhancedRfcSupport","op":"eq","value":true}}
honor_​max_​ageboolean

This instructs edge servers to cache the object for a length of time set by the max-age directive in the response. When present in the origin response, this directive takes precedence over the max-age directive and the default_​ttl setting.

enhanced_​rfc_​support is true
{"displayType":"boolean","tag":"input","type":"checkbox"}
{"if":{"attribute":"enhancedRfcSupport","op":"eq","value":true}}
honor_​s_​maxageboolean

Instructs edge servers to cache the object for a length of time set by the s-maxage directive in the response. When present in the origin response, this directive takes precedence over the max-age directive and the default_​ttl setting.

enhanced_​rfc_​support is true
{"displayType":"boolean","tag":"input","type":"checkbox"}
{"if":{"attribute":"enhancedRfcSupport","op":"eq","value":true}}
honor_​must_​revalidateboolean

This instructs edge servers to successfully revalidate with the origin server before using stale objects in the cache to satisfy new requests.

behavior is either: CACHE_​CONTROL, CACHE_​CONTROL_​AND_​EXPIRES
{"displayType":"boolean","tag":"input","type":"checkbox"}
{"if":{"attribute":"behavior","op":"in","value":["CACHE_CONTROL","CACHE_CONTROL_AND_EXPIRES"]}}
honor_​proxy_​revalidateboolean

With the proxy-revalidate directive present in the response, this instructs edge servers to successfully revalidate with the origin server before using stale objects in the cache to satisfy new requests.

enhanced_​rfc_​support is true
{"displayType":"boolean","tag":"input","type":"checkbox"}
{"if":{"attribute":"enhancedRfcSupport","op":"eq","value":true}}