Estou tentando ter um comportamento básico em relação à minha estratégia de cache: os arquivos devem ser armazenados em cache e revalidados com o servidor a cada vez. Então, eu gostaria que o Apache enviasse um 304 de volta.
Aqui está a caixa de diálogo que acontece para cada atualização do navegador:
Status Code:200 OK
Request Headers
Accept:text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8
Accept-Encoding:gzip,deflate,sdch
Accept-Language:fr-FR,fr;q=0.8,en-US;q=0.6,en;q=0.4
Cache-Control:max-age=0
Connection:keep-alive
Cookie: ...
Host:...
If-Modified-Since:Tue, 14 Oct 2014 15:10:37 GMT
If-None-Match:"1461-505636af08fcd-gzip"
User-Agent:Mozilla/5.0 (X11; Linux i686) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/34.0.1847.116 Safari/537.36
Response Headers
Accept-Ranges:bytes
Cache-Control:No-cache
Connection:Keep-Alive
Content-Encoding:gzip
Content-Length:1412
Content-Type:text/html
Date:Tue, 14 Oct 2014 16:58:05 GMT
ETag:"1461-505636af08fcd-gzip"
Keep-Alive:timeout=5, max=99
Last-Modified:Tue, 14 Oct 2014 15:10:37 GMT
Server:Apache/2.4.6 (Ubuntu)
Vary:Accept-Encoding
(isto é do chrome devtools, com Desativar cache desmarcado)
Você pode ver que a resposta contém o cabeçalho Cache-Control: No-cache e que o cabeçalho If-modified-since corresponde ao Last-modified. O ETag também combina.
O Apache não deveria enviar um 304 nesse caso?
EDITAR
Desativando ETags no apache com
Header unset ETag
torna o comportamento do cache mais previsível ...
Cache-Control:max-age=0
desativou o cache, então você vê aCache-Control:No-cache
resposta.Respostas:
Este parece ser um bug antigo , explicando por que
Header unset ETag
faz a diferença.O Apache 2.4.0+ anexa automaticamente o nome do método de compactação ao ETag (como visto nos cabeçalhos) e evita uma resposta 304.
As versões mais recentes do mod_deflate suportam um DeflateAlterETag que pode ser usado para controlar esse comportamento:
fonte
DeflateAlterETag Remove
opção de faz exatamente issoEste se destaca na solicitação como um pouco estranho:
Provavelmente mais importante, notei que o conteúdo retornado é html. Está sendo gerado dinamicamente? O Apache PODE enviar uma resposta 304, mas, a menos que você esteja servindo conteúdo estático, não é tarefa do Apache fazer essa ligação, e tudo se resume à lógica da sua aplicação. Por exemplo, a maioria dos aplicativos php tem suporte limitado para essas coisas.
Um cache de front-end pode ajudar, pois o aplicativo de cache pode verificar a hora da modificação, a etag etc., mas apenas se os cabeçalhos do aplicativo e da solicitação forem compatíveis com o cache. Por exemplo, o aplicativo precisa definir cabeçalhos apropriados para indicar que o conteúdo pode ser armazenado em cache, e coisas como o cabeçalho de controle de cache em sua solicitação negarão o cache. Seus cabeçalhos não parecem amigáveis ao cache.
fonte
Se você tiver o Apache configurado
Cache-Control:No-cache
, o Apache nunca enviará umHTTP 304 Not modified
para o cliente.Se você deseja revalidar alguns pedidos, coloque
Cache-Control:No-cache
apenas nas páginas em que você precisa. Você não precisa revalidar todos os recursos e está desperdiçando largura de banda ao fazer isso.fonte