HTTP Cache如何计算Age

这里的Age指的是响应头Age,下面内容有部分翻译,也有部分自己的理解,欢迎讨论。

我们用now表示当前主机的当前时间,用request_time表示缓存发起请求的时间,用response_time表示缓存收到响应的时间。

HTTP/1.1要求源服务器的每一个响应都包含一个Date头信息,表示这个响应被源服务器创建的时间,我们用date_value表示这个Date头的值。

HTTP/1.1使用Age响应头表示响应从缓存中拿到时响应的寿命,我们用age_value表示Age头的值。

缓存中响应的寿命可以通过两种完全独立的方式计算:

1.        直接用response_time(缓存收到响应的时间)减去date_value(响应被创建的时间),如果为负数,用0替代。

2.        如果响应路径上的所有缓存实现了HTTP/1.1,则直接用age_value值。

但实际上,我们很难保证响应路径上的所有缓存都实现了HTTP/1.1,所以,同时使用这两种方式,然后进行修正,结果会更可靠:

corrected_received_age= max(response_time - date_value, age_value);

到这里还没有完成最终计算,corrected_received_age只是缓存收到响应时,响应的寿命,没有考虑响应到下一个缓存或客户端的网络延迟时间。

因为网络会有延迟,在传输过程中寿命已经增加了,下一个缓存就得考虑这个因素。对于这个因素,HTTP/1.1采用了一种比较保守的计算方法,假设从请求发起到收到响应的时间就是网络延迟的时间(结果不一定就是实际经过的时间),用response_delay表示:

response_delay= response_time – request_time;

corrected_initial_age= corrected_received_age + response_delay;

response_delay一般指最后一个缓存到客户端的延误时间,如果响应路径上有多个缓存,不需要迭代,因为corrected_received_age是根据缓存收到响应的时间,已经减去了前面的网络延迟。

以上还只是计算响应第一次出现在缓存中时已经拥有的寿命,响应一旦被缓存,就可能被多次使用,这个时候,响应的寿命就得由缓存来计算了。我们用resident_time表示响应在缓存中贮存的时间,用current_age表示响应的当前寿命:

resident_time= now - response_time;

current_age= corrected_initial_age + resident_time;

如果响应路径中有缓存,请求最终受到的响应头Age对应的值是current_age,而不是服务器最初给的Age,因为这个值被缓存已经修改过了。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
缺少HTTP响应头中的Cache-Control字段可能会导致缓存控制不生效。在缺失Cache-Control字段的情况下,浏览器和代理服务器可能会默认将响应内容缓存起来,这可能会导致一些问题。为了解决这个问题,可以在HTTP响应头中添加Cache-Control字段来控制缓存行为。常见的Cache-Control取值有public、private、no-cache、max-age、must-revalidate等。其中,no-cache表示每次请求都要向服务器评估缓存响应的有效性,而max-age表示缓存的最大有效时间。通过设置合适的Cache-Control值,可以确保缓存行为符合预期。另外,还可以使用Pragma字段和Expires字段来进一步控制缓存行为。Pragma字段的值可以设置为no-cache,表示不缓存内容,而Expires字段可以设置为过去的时间,相当于Cache-Control:no-cache的效果。因此,为了解决缺失Cache-Control的问题,可以在HTTP响应头中添加类似以下的代码:header('Cache-Control: no-store, no-cache, must-revalidate'); header("Expires: Mon, 26 Jul 1970 05:00:00 GMT"); \[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* [HTTP缓存带来的“bug”--HTTP 协议 Cache-Control](https://blog.csdn.net/weixin_30924239/article/details/98981719)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [Nginx 关于httpCache-Control详解](https://blog.csdn.net/kane_canpower/article/details/56487591)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值