快取原則互動 — 最長使用期限和最長過時
為了協助確保將最新內容傳回給用戶端應用程式,用戶端快取原則與伺服器重新驗證需求的互動一律會導致最保守的快取原則。 本主題中的所有範例都會說明在 1 月 1 日快取並在 1 月 4 日到期之資源的快取原則。
在下列範例中,最長過時值 (maxStale
) 是與最長使用期限 (maxAge
) 一起使用:
根據
maxAge
值,如果快取原則設定maxAge
= 5 天,但未指定maxStale
值,則在 1 月 6 日之前可以使用內容。 不過,根據伺服器的重新驗證需求,內容會在 1 月 4 日到期。 因為內容到期日較為保守 (更快),所以其優先順序高於maxAge
原則。 因此,內容會在 1 月 4 日到期,而且必須重新驗證,即使未達到其最長使用期限也是一樣。根據
maxAge
值,如果快取原則設定maxAge
= 5 天且maxStale
= 3 天,則在1 月 6 日之前可以使用內容。 根據maxStale
值,在 1 月 7 日之前可以使用內容。 因此,會在 1 月 6 日重新驗證內容。根據
maxAge
值,如果快取原則設定maxAge
= 5 天且maxStale
= 1 天,則在 1 月 6 日之前可以使用內容。 根據maxStale
值,在 1 月 5 日之前可以使用內容。 因此,會在 1 月 5 日重新驗證內容。
最長使用期限小於內容到期日時,一律會使用更保守的快取行為,而且最長過時值沒有任何作用。 下列範例說明達到最長使用期限 (maxAge
) 但在內容到期之前,設定最長過時 (maxStale
) 值的效果:
如果快取原則設定
maxAge
= 1 天,但未指定maxStale
值的值,則會在 1 月 2 日重新驗證內容,即使未到期也是一樣。如果快取原則設定
maxAge
= 1 天且maxStale
= 3 天,則會在 1 月 2 日重新驗證內容,來強制執行更保守的原則設定。如果快取原則設定
maxAge
= 1 天且maxStale
= 1 天,則會在 1 月 2 日重新驗證內容。