Кеширование и SSI
Igor Sysoev
is at rambler-co.ru
Fri Aug 28 16:31:24 MSD 2009
On Fri, Aug 28, 2009 at 03:24:30PM +0300, Roman wrote:
> Hello Igor,
>
> Thursday, August 27, 2009, 3:11:15 PM, you wrote:
>
> IS> On Thu, Aug 27, 2009 at 02:51:32PM +0300, Roman wrote:
>
> >> Добрый день,
> >> имеется nginx version: nginx/0.8.10.
> >>
> >> Собственно что пытаюсь сделать,
> >> страницы генерятся и кешируются правильно,
> >>
> >> proxy_cache_key "$uri$is_args$args$cookie_auth" выглядит вот так,
> >>
> >> кука 'auth' для каждого пользователя уникальна, получается что пользы
> >> от кеширования для большого кол-ва пользователей не очень много, т.к.
> >> все равно постоянно приходится дергать бакенд, базу и т.д.
> >>
> >> Подумал сделать так: из ключа выкинуть $cookie_auth
> >> proxy_cache_key "$uri$is_args$args";
> >>
> >> ну а идентификатор ползователей выдергивать с помощью SSI
> >> <!--# include virtual="/get_mem_id.php?auth=cookie_auth" set="member_id" -->
> >> или же получить имя
> >> <!--# echo var="cookie_username" default="" -->
> >> ну и так далее...
> >>
> >> но что-то у меня не рабоатет, либо криво настроено, либо так нельзя
> >> сделать.
> >>
> >> Подскажите, пожалуйста, как работает кеширование, а именно,
> >> кешируется ответ с уже обработанными SSI инструкциями или же нет?
>
> IS> location / {
> IS> ssi on;
> IS> proxy_pass ...
> IS> proxy_cache_key $request_uri;
> IS> }
>
> IS> location = /get_mem_id.php {
> IS> proxy_pass ...
> IS> proxy_cache_key $cookie_auth;
> IS> }
>
> Проведя эксперементы, выяснил что в такой конструкции
> <!--# include virtual="/get_mem_id.php?auth=cookie_auth" set="member_id" -->
> подзапрос "/get_mem_id.php?auth=cookie_auth"
> обрабатывается в том же локейшене что и основной запрос.
Не должен. Нужен отладлочный лог.
> Получается, что то, что мне нужно скорее всего реализовать не
> получится.
--
Игорь Сысоев
http://sysoev.ru
More information about the nginx-ru
mailing list