Maxim Dounin
November 28, 2013 04:20AM
Hello!

On Wed, Nov 27, 2013 at 04:21:37PM -0500, S.A.N wrote:

> > use case и о происхождении требования о недопустимости кеширования
> > даже на 1 секунду. Возможно, это позволило бы пересмотреть
> > существующее поведение при max-age=0, благо в Cache-Control есть и
> > другие способы запрета кеширования.
>
> use case продиктован нашей бизнес логикой, мы кешируем все даже страницы для
> залогиненых пользователей (персонал данные подтягиваются через ajax с
> использованием клиентского кэширования браузера), в этом есть смысл, цифры я
> уже писал, разница скорости в генерации страницы и в ревалидации отличается
> в десятки раз, в пользу ревалидации.
>
> Есть сайт с хорошей посещаемостью, залогиненые пользователи имеют
> возможность общатся, создавать свой контент, редактировать, удалять, есть
> так же платные сервисы.
>
> Наши клиенты не хотят и не должны ждать, даже если это одна секунда, ну
> например, клиент написал комментарий на сайте, POST ушел на сервер, если у
> нас кеширования на 1 секунду, мы клиенту не можем сразуже показать новую
> страницу, должны сделать задержку на 1 сек потом обновить его страницу или
> как на Хабре все комментарии видны с задержкой и люди это терпят.

Т.е. задача - показать клиенту, добавившему комментарий с помощью
POST'а, страницу с его комментарием непосредственно после
перенаправления, отдаваемого на POST, правильно?

Спасибо, так констуркция понятна, хотя и несколько странна.
Just in case, альтернативные решения на вскидку:

- Добавлять комментарий без перезагрузки страницы javascript'ом,
отправлять на сервер - через ajax. Так, насколько я понимаю,
сейчас делают чуть менее, чем все, в том числе упоминаемый вами же
facebook.

- Добавлять комментарий, после чего возвращать перенаправление на
специальный адрес (e.g. со случайным числом в аргументе) для
прохода кешей. Такой подход позволяет не зависеть от реализуемых
по пути алгоритмов кеширования, и в то же время обеспечить
нормальное кеширование страниц (и беспроблемную навигацию по
истории). Кеши страниц на nginx'е при этом можно склеить с
помощью грамотного указания ключа кеширования и использования
proxy_cache_bypass. Так делали раньше чуть менее, чем все.

[...]

--
Maxim Dounin
http://nginx.org/en/donation.html

_______________________________________________
nginx-ru mailing list
nginx-ru@nginx.org
http://mailman.nginx.org/mailman/listinfo/nginx-ru
Subject Author Posted

Cache Revalidate

S.A.N November 26, 2013 09:07PM

Re: Cache Revalidate

Maxim Dounin November 27, 2013 09:14AM

Re: Cache Revalidate

denis November 27, 2013 09:48AM

Re: Cache Revalidate

S.A.N November 27, 2013 01:22PM

Re: Cache Revalidate

Maxim Dounin November 27, 2013 01:42PM

Re: Cache Revalidate

S.A.N November 27, 2013 02:30PM

Re: Cache Revalidate

Maxim Dounin November 27, 2013 03:24PM

Re: Cache Revalidate

S.A.N November 27, 2013 04:21PM

Re: Cache Revalidate

S.A.N November 27, 2013 04:47PM

Re: Cache Revalidate

Alexander Moskalenko November 27, 2013 04:50PM

Re: Cache Revalidate

S.A.N November 27, 2013 05:02PM

Re: Cache Revalidate

Maxim Dounin November 28, 2013 04:20AM

Re: Cache Revalidate

S.A.N November 28, 2013 04:56AM

Re: Cache Revalidate

Роман Москвитин November 28, 2013 05:06AM

Re: Cache Revalidate

S.A.N November 28, 2013 05:15AM

Re: Cache Revalidate

Роман Москвитин November 28, 2013 05:34AM

Re: Cache Revalidate

S.A.N November 28, 2013 05:51AM

Re: Cache Revalidate

Роман Москвитин November 28, 2013 05:54AM

Re: Cache Revalidate

grygory.mos December 06, 2013 01:56AM

Re: Cache Revalidate

Maxim Dounin December 06, 2013 08:18AM

Re: Cache Revalidate

grygory.mos December 06, 2013 02:38PM

Re: Cache Revalidate

S.A.N December 06, 2013 05:52PM

Re: Cache Revalidate

grygory.mos December 22, 2013 06:48PM



Sorry, only registered users may post in this forum.

Click here to login

Online Users

Guests: 293
Record Number of Users: 8 on April 13, 2023
Record Number of Guests: 421 on December 02, 2018
Powered by nginx      Powered by FreeBSD      PHP Powered      Powered by MariaDB      ipv6 ready