Re: не работает proxy_cache

Евгений Торопов jt на aaanet.ru
Ср Июл 20 13:37:03 MSD 2011


On Jul 20, 2011, at 12:56 PM, Maxim Dounin wrote:

> Hello!
> 
> On Wed, Jul 20, 2011 at 12:24:59PM +0400, Евгений Торопов wrote:
> 
>> Добрый день,
>> 
>> Не могу понять, что мешает кэшированию.
>> 
>> Кэш-конфиг:
>> 
>> proxy_cache_path /opt/local/nginx/cache levels=1:2 keys_zone=sup:32m max_size=1024m inactive=1h;
>> 
>> proxy_cache                 sup;
>> proxy_cache_valid           1h;
>> 
>> proxy_cache_key            "$host$request_uri";
>> proxy_cache_methods         POST;
>> 
>> 
>> 
>> Отрывок дебаг лога:
> 
> [...]
> 
>> 2011/07/20 12:02:20 [debug] 99556#0: *15 http proxy status 200 "200 OK"
>> 2011/07/20 12:02:20 [debug] 99556#0: *15 http proxy header: "Date: Wed, 20 Jul 2011 08:02:16 GMT"
>> 2011/07/20 12:02:20 [debug] 99556#0: *15 http proxy header: "Server: Apache/2.0.52 (Red Hat)"
>> 2011/07/20 12:02:20 [debug] 99556#0: *15 http proxy header: "Content-Encoding: deflate"
>> 2011/07/20 12:02:20 [debug] 99556#0: *15 http proxy header: "Vary: Accept-Encoding"
>> 2011/07/20 12:02:20 [debug] 99556#0: *15 http proxy header: "Set-Cookie: JSESSIONID=avIghzWKEQxa; path=/"
>> 2011/07/20 12:02:20 [debug] 99556#0: *15 http proxy header: "Connection: close"
>> 2011/07/20 12:02:20 [debug] 99556#0: *15 http proxy header: "Content-Type: text/xml; charset=ISO-8859-1"
>> 2011/07/20 12:02:20 [debug] 99556#0: *15 http proxy header done
> 
> Как минимум - ставится сессионная кука, nginx такой ответ 
> кешировать не будет, если его специально не попросить.
> 
> Попросить кешировать (и спрятать куки, чтобы не выставлять их всем 
> клиентам из кеша) можно так:
> 
>    proxy_ignore_headers Set-Cookie;
>    proxy_hide_header Set-Cookie;
> 
> Ещё я бы рекомендовал либо добавить в ключ кеширования 
> Accept-Encoding ($http_accept_encoding), либо выключить сжатие на 
> бекендах.  Сейчас nginx не понимает Vary, и в вашем случае в кеш 
> ляжет ответ сжатый deflate'ом, что может не устроить браузер, 
> который потом будет получать ответ из кеша.  Простейший способ 
> выключить сжатие - просто не пропускать на бекенд заголовок 
> Accept-Encoding, как-то так:
> 
>    proxy_set_header Accept-Encoding "";
> 
> Maxim Dounin
> 
> _______________________________________________
> nginx-ru mailing list
> nginx-ru at nginx.org
> http://nginx.org/mailman/listinfo/nginx-ru

Большое спасибо, заработало.

Евгений
jt at aaanet.ru




Подробная информация о списке рассылки nginx-ru