Re: Управление кешом - фичареквест
Maxim Dounin
mdounin at mdounin.ru
Fri Jul 26 14:51:13 UTC 2013
Hello!
On Fri, Jul 26, 2013 at 11:53:33AM +0400, Dmitry E. Oboukhov wrote:
> поигрался немного с кешами.
>
> интересно, включаем кеш для location'а на скажем 0-30 минут и далее
> бакенд определяет что данную страницу надо закешировать на скажем 20
> секунд выдавая заголовок X-Accel-Expires: 20.
> это классная фича!
>
> но вот если посмотреть на любой сайт с кешированием, то можно увидеть
> что какую-то информацию мы можем выдать в кеш, но при этом кеш валиден
> будет *до определенного действия пользователя*.
>
> например (утопический пример) мы на сайте кешируем список
> пользователей написавших больше всего сообщений (ТОП по
> пользователям).
> понятное дело, такой ТОП меняется редко и можно смело ему выдать
> скажем 10 минут время жизни кеша и все будет хорошо.
> но допустим у нас задача есть чтобы этот ТОП выводился более
> качественно. становится ТОП'ом другой пользователь (входит в ТОП10) и
> сразу картинка перестраивается (без лага в 0-10 минут).
>
> для такой задачи просто определение времени жизни кеширования из
> бакенда не подойдет. еще нужно иметь возможность сказать что кеш
> невалиден nginx'у.
>
> и вот тут фичареквест добавить опцию (насколько я понимаю не должно
> быть сложным):
>
> у нас есть один хидер на управление кешом:
>
> X-Accel-Expires: [ секунд | @секунд ]
>
> - определяет сколько времени данная страница может находиться в кеше
>
> а можно сюда добавить еще хидер, например:
>
> X-Cache-Invalid: "/users/top/123?all=yes"
>
> - определяет что с данного момента определенный набор страниц
> находящихся в кеше (набор = если несколько таких заголовков выдали)
> невалиден.
>
> Тогда если бакенд выдал такой заголовок (или несколько таких
> заголовков), чтобы nginx по факту выдачи такого ответа сбросил кеши,
> связанные с данными урлами?
Помнится мне, когда-то давно Игорь писал в рассылку, что планирует
нечто подобное сделать. А сейчас даже есть draft RFC на
аналогичную тему, тут:
http://tools.ietf.org/html/draft-nottingham-linked-cache-inv-04
Я, правда, сомневаюсь, что draft взлетит, но вообще
функциональность, как мне кажется, интересная.
С точки зрения реализации в nginx'е есть, правда, один нюанс:
ключ кеширования может задаваться произвольно, и не так просто
вычислить, что именно нужно убрать из кеша.
--
Maxim Dounin
http://nginx.org/en/donation.html
Подробная информация о списке рассылки nginx-ru