ПРОЕКТЫ 


  АРХИВ 


Apache-Talk @lexa.ru 

Inet-Admins @info.east.ru 

Filmscanners @halftone.co.uk 

Security-alerts @yandex-team.ru 

nginx-ru @sysoev.ru 


  СТАТЬИ 


  ПЕРСОНАЛЬНОЕ 


  ПРОГРАММЫ 



ПИШИТЕ
ПИСЬМА












     АРХИВ :: nginx-ru
Nginx-ru mailing list archive (nginx-ru@sysoev.ru)

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: feature request: sendfile management



On Thursday 25 October 2007 18:49, Alex Vorona wrote:
> Andrei Nigmatulin пишет:
> > On Thursday 25 October 2007 18:13, Alex Vorona wrote:
> >> MZ пишет:
> >> простым #ifdef тут наврядли обойтись получится. На одном и том же файле
> >> в течение одного запроса sendfile()'ы  могут и блокироваться и не
> >> блокироваться, например в зависимости от загрузки дисков и/или от
> >> скорости канала к клиенту. Можно конечно упростить задачу, и, как только
> >> sendfile() заблокировался первый раз - продолжать отдавать файл через
> >> read/write. Насколько эта схема будет эффективной - вопрос второй.
> >>
> >> Какие ещё могут быть варианты ухода nginx от блокировки на диске,
> >> забывая про AIO?
> >
> > Например, отдельный поток в котором выполняются все блокирующиеся
> > операции. И уведомление о готовности основного потока через
> > pipe/socketpair.
>
> соотвественно каждый воркер должен стать многопоточным. Как с
> многопоточностью обстоят дела во FreeBSD ? И чем тогда ситуация с N
> двухпоточными воркерами будет отличаться от одного многопоточного воркера?

Тормозов со стороны жесткого диска на практике не избежать и воркер всегда 
будет блокироваться как минимум на open и stat. Но можно избежать тормозов в 
сетевом io для тех соединений, которые обрабатываются в том же воркере. Это 
возможно если один поток всегда будет выполнять заведомо неблокирующиеся 
операции плюс все сетевое io, а второй - все блокирующиеся.


-- 
Andrei Nigmatulin
GPG PUB KEY 6449830D

Now I lay me down to sleep(3)
Pray the OS my core to keep
If I die before I wake
Pray the Disk my core to take


 




Copyright © Lexa Software, 1996-2009.