为什么各大网站都使用 gzip?

发布于 2025-01-02 21:43:35 字数 942 浏览 0 评论 0原文

我刚刚搜索了 gzipDeflate,发现Deflate更好。

但是当我检查响应时Google、Facebook 和 StackExchange 的标头都使用 GZIP。为什么他们使用 gzip 而不是 Deflate?

I just searched about gzip and Deflate, and found out that Deflate is better.

But when I checked the response headers of Google, Facebook and StackExchange, all of them were using GZIP. Why do they use gzip instead of Deflate?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

傲鸠 2025-01-09 21:43:35

这显然是由于选择“Deflate”这个名字而引起的误解。 http 标准明确指出“deflate”实际上意味着 zlib 格式:

    The "zlib" format defined in RFC 1950 [31] in combination with
    the "deflate" compression mechanism described in RFC 1951 [29].

然而,早期的 Microsoft 服务器会错误地为“Deflate”提供原始 deflate(即,仅 RFC 1951 数据,而没有 zlib RFC 1950 包装器)。这导致了问题,浏览器必须两种方式都尝试,最终只使用 gzip 更可靠。

使用 gzip 代替“Deflate”(zlib) 对带宽和执行时间的影响相对较小。所以我们现在就这样,而且很可能会继续下去。

区别在于 gzip 多了 12 个字节,计算 CRC(而不是 Adler-32)的 CPU 时间也稍长一些。

It is apparently due to a misunderstanding resulting from the choice of the name "Deflate". The http standard clearly states that "deflate" really means the zlib format:

    The "zlib" format defined in RFC 1950 [31] in combination with
    the "deflate" compression mechanism described in RFC 1951 [29].

However early Microsoft servers would incorrectly deliver raw deflate for "Deflate" (i.e. just RFC 1951 data without the zlib RFC 1950 wrapper). This caused problems, browsers had to try it both ways, and in the end it was simply more reliable to only use gzip.

The impact in bandwidth and execution time to use gzip instead of "Deflate" (zlib), is relatively small. So there we are and there it is likely to remain.

The difference is 12 more bytes for gzip and slightly more CPU time to calculate a CRC instead of an Adler-32.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文