【问题标题】:How long are files usually kept in a browser's cache文件通常在浏览器缓存中保存多长时间
【发布时间】:2010-05-19 22:07:10
【问题描述】:

文件通常在浏览器缓存中保存多长时间?我想知道一般人群 - 我需要等待多长时间才能合理地确定大多数人的缓存会重新获取文件?

【问题讨论】:

    标签: browser-cache


    【解决方案1】:

    这在很大程度上取决于个人、浏览器和设置。

    浏览器通常会为此任务保留一定数量的磁盘空间,例如 12 MiB。如果用户无限期地停止使用浏览器。如果他/她很少使用浏览器,它将一直持续到到期 - 无论是内部策略还是 HTTP 标头。如果他/她大量使用浏览器,则可能需要 12 分钟甚至更短。

    我相信很难说“一般”,因为我有一个网站,其中 50% 的条目来自 Firefox,49% 来自 Opera,而当时 IE 拥有超过 75% 的市场份额。如果您网站的目标受众是大量使用浏览器的用户,那么它可能非常短。另一方面,如果您的网站只是访问过的网站,则几乎永远不会访问。

    【讨论】:

    • 当出现“Expires”、“Cache-Control”或“Last-Modified”等标头时,浏览器不会“无限期地”将项目保存在缓存中。相反,浏览器将为该内容设置特定的到期时间。您的回答暗示了这一点,但应该明确说明。
    • @StephenOstermiller - 谢谢。我的意思是“(即直到到期)”,但我希望现在更清楚。
    • @StephenOstermiller 好吧,从技术上讲,他不正确,因为如果用户停止使用浏览器,缓存将一直保留到再次使用浏览器?如我错了请纠正我。我的意思是,这似乎是一个愚蠢的观点,除非从安全角度来看,可能会从 PC 上恢复缓存数据,因为只要不打开浏览器,它就仍然存在。我错了吗?
    • 在某些情况下,浏览器不再使用并且仍然有非常旧的缓存。然而,问题在于浏览器是否重新获取文件,而不是非活动浏览器。
    • @StephenOstermiller 您似乎重申了您 3 年前写的内容。我试图通过“如果他/她很少使用浏览器,它将一直到到期 - 无论是通过内部策略还是通过 HTTP 标头。”来澄清它。 TBH 我不确定如何进一步澄清。
    【解决方案2】:

    正如其他答案所述,这取决于浏览器设置。但请注意,缓存文件并不一定意味着不会从您的站点获取更改。如果配置为这样做,浏览器将向服务器发送请求,其中包含有关缓存文件日期的详细信息。当没有更改时,服务器然后响应“好的,使用您的缓存 - 这是最新版本”。这个回复很小,很快就发送了。如果服务器版本已更新,则服务器将响应新版本。

    浏览器向服务器发送请求的频率是特定于浏览器的 - 它们可以配置为每次检查更新、每小时一次、每天一次、从不检查或介于两者之间。服务器还可以指定浏览器检查更新的频率。

    这只是一个草图 - 它被简化且不完整。有关完整的详细信息,请参阅W3C - HTTP/1.1 Caching

    【讨论】:

      【解决方案3】:

      通常文件会保留在缓存中,直到空间用完。有一篇文章描述了一些流行浏览器的默认设置: It's Time to Rethink the Default Cache Size of Web Browsers

      正如 Maciej 所说,这也是每个人浏览多少的问题。考虑将访问您网站的用户群,以及您网站的带宽占用程度(如果普通用户从您的网站下载大量内容,他们很可能会很快填满缓存)。

      如果需要刷新缓存,可以强制页面不缓存文件。

      【讨论】:

      • 这是来自archive.org的the link to last working copy。请注意,该文档已有约 8 年历史(2008 年),这在浏览器行为方面相当古老。当您询问 Google 时,这个问题仍然排在前 10 位。
      【解决方案4】:

      取决于服务器指定的时间。服务器在响应头中发回参数。他们可以指定 max-age(文件过期前缓存多长时间,以毫秒为单位)或过期日期(文件过期的日期)。如果两者都有,则 max-age 将优先。

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 2012-02-26
        • 2019-06-18
        • 2012-08-26
        • 1970-01-01
        • 1970-01-01
        • 2020-08-03
        • 2015-05-09
        相关资源
        最近更新 更多