HELP! fastcgi_cache_bypass - оно вообще работает хоть у кого-нить?

Влад Максимов vladsm на mail.ru
Чт Фев 24 15:19:52 MSK 2011


Наткнулся на неприятное: не работает fastcgi_cache_bypass.
Или я просто не умею его готовить, что тоже возможно.

Стандартная схема frontend->backend

...
    location /cached/block/ {

      rewrite ^/cached(/.+)$ $1 break;

      include fastcgi_params;

      fastcgi_pass        localhost:9005;
      fastcgi_param     SERVER_NAME     $host;
      fastcgi_param     SCRIPT_FILENAME $backend_root_index;
      fastcgi_param     REQUEST_URI     $uri;

      fastcgi_cache             testcache;
      fastcgi_cache_key         "$request_method|$host|$uri";
      fastcgi_cache_valid       200 302 1d;

      fastcgi_no_cache $arg_nocache;
      fastcgi_cache_bypass $arg_nocache;

      fastcgi_cache_bypass $arg_skipcache;
  }
...

Если я правильно понимаю документацию, то при обращении http://mydomain.com/cached/block/someData/  - nginx обратится к бэкенду, закеширует ответ на 1 день и содержимое ответа отдаст клиенту.
При этом если я обращусь с ?skipcache ( http://mydomain.com/cached/block/someData/?skipcache=1 ) то nginx не должен искать эти данные в кеше, а должен обратиться на бэкенд за свежими данными, после чего уже положить их в кеш и отдать клиенту.

И вот тут начинается самое интересное:
  1. если я обращаюсь http://mydomain.com/cached/block/someData/  - всё работает, как и предполагалось - кешируется ответ бэка, и последующим запросам клиентов отдаётся всё из кеша
  2. если я обращаюсь http://mydomain.com/cached/block/someData/?skipcache=1 - всё ломается. При этом в зависимости от размера ответа бэка, этот ответ всё-таки может оказаться в кеше и попасть клиенту (но очень серьёзно побитый), или же я в логе получу строчку в духе upstream sent unsupported FastCGI protocol version: 118 while reading upstream, client: 192.168.1.5, server: some.trashcan.dev, request: "GET /cached/block/someData?skipcache=1 HTTP/1.1", upstream: "fastcgi://127.0.0.1:9005", host: "some.trashcan.dev"
  3. однако если я обращусь http://mydomain.com/cached/block/someData/?nocache=1 (то есть пробрасывать на бэк и при этом не сохранять в кеш) - тоже всё будет работать. 

Что делать? Куда копать? 
Что я пропустил или не понял?

--------------------
nginx -V

nginx version: nginx/0.8.54
built by gcc 4.1.2 20080704 (Red Hat 4.1.2-48)
configure arguments: --with-http_image_filter_module --with-http_stub_status_module --with-http_realip_module --with-debug 

nginx: nginx version: nginx/0.9.5
nginx: built by gcc 4.1.2 20080704 (Red Hat 4.1.2-48)
nginx: configure arguments: --with-http_image_filter_module --with-http_stub_status_module --with-http_realip_module --with-debug





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