On Fri, Mar 23, 2007 at 09:12:15PM +0300, Vlad S. Maximov wrote:
> nginx 0.5.14
>
> Имеем конфиг:
>
> ...
> upstream backend {
> server localhost:80;
> }
> ...
> location /memcached/ {
> internal;
> ssi on;
> set $memuri $uri;
> set $memcached_key "$memuri";
> memcached_pass localhost:10000;
> error_page 404 =200 /memcached-miss$memuri;
> }
> ...
> location /memcached-miss/ {
> internal;
> ssi on;
> rewrite ^/memcached-miss/(.*)$ /$1 break;
> proxy_set_header Host $host;
> proxy_set_header X-Real-IP $remote_addr;
> proxy_pass http://backend;
> proxy_redirect off;
> }
> ...
>
> Имеем примерно следующий index.shtml:
> ...
> <!--# include virtual="/memcached/frontpage/part1/" -->
> <!--# include virtual="/memcached/frontpage/part2/" -->
> <!--# include virtual="/memcached/frontpage/part3/" -->
> ...
>
> В итоге при обращении к странице в логах бэкенда имеем:
> ...
> GET /memcached/frontpage/part3/
> GET /memcached/frontpage/part3/
> GET /memcached/frontpage/part3/
> ...
> но если поставить в каждом из инклюдов wait="yes", то получаем желаемое
> ...
> GET /memcached/frontpage/part1/
> GET /memcached/frontpage/part2/
> GET /memcached/frontpage/part3/
> ...
>
> Почему такое происходит (параллельные запросы идут по последнему uri)?
> Как от этого избавиться?
Дело в том, что
1) переменные общие для всех подзапросов
2) большинство переменных кэшируется, поэтому для /memcached-miss$memuri
испорльзуется $memuri, равная /memcached/frontpage/part3/.
Переменная $uri не кэшируется, но в nginx есть ошибка из-за которой
даже значение $uri кэшируется даже в такой конфигцурации:
set $memcached_key $uri;
memcached_pass localhost:10000;
error_page 404 =200 /memcached-miss$uri;
Прилагаемый патч ошибку исправляет.
--
Игорь Сысоев
http://sysoev.ru