Nginx-ru mailing list archive (nginx-ru@sysoev.ru)
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: Bug ? 304 status - Cache-Control
- To: nginx-ru@xxxxxxxxx
- Subject: Re: Bug ? 304 status - Cache-Control
- From: "S.A.N" <nginx-forum@xxxxxxxx>
- Date: Fri, 03 Jan 2014 20:07:41 -0500
- Dkim-signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=selenium.jlkhosting.com; s=x; h=Date:Sender:From:References:In-Reply-To:Message-ID:Content-Transfer-Encoding:Content-Type:Subject:To; bh=mww/RU/CeL3sg2JfZ04nP0ud5BNoUfqdk12PEhZFLnY=; b=CfjG5azmvm9YF6faZotIPoU6mcdtnYLt6e9VJAurLd5kS5RJogeFXge5wikFFKc8CPxkj8A/6u7GGsTHQe/mHSbrk98nlE5lcO3+BtXSsERrsds6uR4QmhRPaGyOYM1L8Lv9tUgm+qx9CjGsgpdQaqom9KH7Hoy9fMklCqVCvhc=;
- In-reply-to: <20140104003018.GM95113@mdounin.ru>
- References: <20140104003018.GM95113@mdounin.ru>
> И если отдать 304 на основании значения If-None-Match, то в кеше
> nginx'а будет оставлен потенциально устаревший ответ. Т.е.
> If-None-Match нужно просто убрать из рассмотрения при генерации
> ответа на бекенде, иначе корректной работы не добиться.
Дело в том, что изначально кеширования на бекенде, разрабатывалось для
клиентского кеширования (в браузере), как уже писал не однократно,
ревалидация происходит по If-None-Match, ревалидировать по заголовоку
If-Modified-Since будет очень накладно, для больших сайтов, по этому мы
сейчас используем Nginx кеширования на временной интервал. А там где контент
завязан на пользователя, используется только клиентское (private)
кеширования браузера.
Бекенд, не знает и не должен знать, какой тип кеша ему нужно ревалидировать,
клиентский или кеш Nginx, по хорошему в первом и во втором случаи, механизм
должен быть полностью одинаковым.
По этому чтобы иметь возможность использовать клиент кеширования, мы в
конфиге прописали
fastcgi_param HTTP_IF_NONE_MATCH $http_if_none_match if_not_empty
Без этого работать с клиенским кешем невозможно, по причине удаления этих
заголовком при включении fastcgi_cache_revalidate в Nginx.
Наша ошибка была в том, что бекенд приложения игнорировало отсутствия
If-Modified-Since, но проводило ревалидацию при наличии If-None-Match и
отвечало статусом 304 если ETag актуальный.
Мы это исправили добавив проверку на наличия If-Modified-Since.
Теперь все работает правильно, при клиент кешировании, мы в заголовок
Cache-Control пишем дерективу private, это запретит Nginx кешировать данный
ответ и таким образом он не попадет в кеш не при 200 статусе и так же ответ
в 304 статусе в кеш не попадет.
Posted at Nginx Forum:
http://forum.nginx.org/read.php?21,245951,245996#msg-245996
_______________________________________________
nginx-ru mailing list
nginx-ru@xxxxxxxxx
http://mailman.nginx.org/mailman/listinfo/nginx-ru
|