платная доработка nginx

Igor Sysoev is at rambler-co.ru
Wed Jan 28 17:31:52 MSK 2009


On Wed, Jan 28, 2009 at 04:48:25PM +0300, Igor Sysoev wrote:

> On Wed, Jan 28, 2009 at 01:19:59PM +0000, Valery Kholodkov wrote:
> 
> > 
> > "Igor Sysoev" <is at rambler-co.ru> wrote:
> > 
> > > SSI-фильтру не нужно иметь тело запроса. SSI-фильтру нужно просто
> > > вызвать
> > > подзапрос, а уже этот подзапрос, если он обрабатывается
> > > proxy/fastcgi,
> > > сам прочитает тело.
> > 
> > Это будет работать, если параллельные подзапросы смогут координировать прием тела между собой. В противном случае все подзапросы унаследуют пустое тело и только один его прочитает. В данный момент ни подзапросы не координируют прием тела, ни статический хэндлер не откладывает отброс тела.
> 
> Приём тела сейчас должен координироваться (не проверял), потому что из
> всех параллельных подзапросов с клиентом может работать только один -
> если бы этого не было, то в выводе была бы мешанина.
> 
> Единственная на данный момент проблема - тело достаётся только
> первому подзапросу, прочитавшему тело. Решается хранением тела в основном
> запросе.
> 
> > Хотя идея хорошая, будет потребляться меньше ресурсов.
> > 
> > > > > В смысле - фаза приёма тела вызывается после контентной ?
> > > > 
> > > > Да.
> > > 
> > > Это сути не отличается от того, что я хотел сделать - откладывать
> > > дискард
> > > тела до последнего, если тело не было прочитано. Вопрос лишь в том,
> > > когда
> > > собственно можно делать дискард.
> > 
> > Этот вопрос ставит под сомнение возможность элегантной реализации как таковой, поскольку узнать, что в теле нет ни одного post-подзапроса можно только после того, как SSI-фильтр полностью завершит обработку тела. 
> 
> О чём я, собственно, и написал в том письме.
> Придётся возвращаться к тому самому патчу.

Впрочем, у меня появились такие соображения:

1) GET и HEAD в статическом модуле сразу отбрасывают тело.

2) POST в статику ничего не делает с телом. Таким образом, тело или будет
   прочитано одним из подзапросов, или же не прочитано вообще.

По окончании любого запроса неиспользумое тело отбрасывается.
Как я уже говорил, это может привести к dead lock'у, если тело ответа
достаточно большое, а браузер не хочет его принимать, пока не передаст
свое, тоже достаточно большое, тело запроса. Однако, эта ситуация
может возникнуть только при неверном использовании сайта - при
больших POSTах в статические страницы, в которых нет SSI.

Таким образом, при корректных POSTах всё будет работать (*), а при
некорректных - просто отваливаться по таймауту.

*) dead lock может возникнуть, если перед первым SSI, который будет
читать тело запроса, будет много данных, которые не поместятся в
output_buffers + в ядерные TCP-буфера сервер и клиента.
Лечится увеличением output_buffers.


-- 
Игорь Сысоев
http://sysoev.ru





More information about the nginx-ru mailing list