android http etag,你知道 http 响应头中的 ETag 是如何生成的吗

关于 etag 的生成需要满足几个条件

当文件不会更改时,etag 值保持不变。所以不能单纯使用 inode

便于计算,不会特别耗 CPU。这样子 hash 不是特别合适

便于横向扩展,多个 node 上生成的 etag 值一致。这样子 inode 就排除了

那么在nginx中的etag是如何生成的?

nginx 中 ETag 的生成

我在网上找到一些资料与源代码了解到了 etag 的计算方法。由 python 伪代码表示计算方法如下

etag = '{:x}-{:x}'.format(header.last_modified, header.content_lenth)复制代码

etag->value.len = ngx_sprintf(etag->value.data, "\"%xT-%xO\"",

r->headers_out.last_modified_time,

r->headers_out.content_length_n)

- etag->value.data;复制代码

总结:nginx中etag由响应头的Last-Modified与Content-Length表示为十六进制组合而成。

随手在我的k8s集群里找个 nginx 服务测试一下

$ curl --head 10.97.109.49

HTTP/1.1 200 OK

Server: nginx/1.16.0

Date: Tue, 10 Dec 2019 06:45:24 GMT

Content-Type: text/html

Content-Length: 612

Last-Modified: Tue, 23 Apr 2019 10:18:21 GMT

Connection: keep-alive

ETag: "5cbee66d-264"

Accept-Ranges: bytes复制代码

由 etag 计算 Last-Modified 与 Content-Length,使用 js 计算如下,结果相符

> new Date(parseInt('5cbee66d', 16) * 1000).toJSON()

"2019-04-23T10:18:21.000Z"

> parseInt('264', 16)

612复制代码

Last-Modified,ETag 与协商缓存

我们知道协商缓存有两种方式

Last-Modified/if-Modified-Since

ETag/If-None-Match

既然在 nginx 中 ETag 由 Last-Modified 和 Content-Length 组成,那它便算是一个加强版的 Last-Modified 了,那加强在什么地方呢?

Last-Modified是由一个unix timestamp表示,则意味着它只能作用于秒级的改变

我是山月,你可以添加我微信 shanyue94 与我交流

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值