How do HTTP proxy caches decide between serving identity- vs. gzip-encoded resources?
Posted
by mrclay
on Stack Overflow
See other posts from Stack Overflow
or by mrclay
Published on 2009-03-29T16:39:35Z
Indexed on
2010/03/17
20:31 UTC
Read the original article
Hit count: 229
An HTTP server uses content-negotiation to serve a single URL identity- or gzip-encoded based on the client's Accept-Encoding
header.
Now say we have a proxy cache like squid between clients and the httpd.
If the proxy has cached both encodings of a URL, how does it determine which to serve?
The non-gzip instance (not originally served with Vary
) can be served to any client, but the encoded instances (having Vary: Accept-Encoding
) can only be sent to a clients with the identical Accept-Encoding
header value as was used in the original request.
E.g. Opera sends "deflate, gzip, x-gzip, identity, *;q=0"
but IE8 sends "gzip, deflate"
. According to the spec, then, caches shouldn't share content-encoded caches between the two browsers. Is this true?
© Stack Overflow or respective owner