On Sat, Apr 21, 2007 at 07:09:27PM +0400, Александр Ворона wrote:
> Igor Sysoev пишет:
> >Дело в том, что lighttpd не использует EPOLLET, а nginx - использует.
> >Когда патч в ядре ограничивает объём передаваемых данных, то происходит
> >следующее - EPOLLET фиксирует состояние, что буфер свободен, об этом
> >сообщается приоложению (nginx'у), он делает sendfile. sendfile быстро
> >передаёт ограниченный объём, буфер по-видимому после этого полностью
> >свободный и новое событие не приходит.
> модифицировал немного патч
> - res=*((int *)(&(sbuff[0])));
> + res=104857600;
>
> в результате имею затыкающийся после 100м-вого sendfile()'а nginx. Буфер
> сокета выше 1М не поднимался. Подозреваю, что любое значение count у
> sendfile(), меньшее оставшегося неотосланного количества байт в файле,
> но приводящее к отдаче count байтов за один sendfile(), вызовет затык -
> не приходит событие(передано ровно запрошенное количество байт, а не
> меньше). В случае настроящего неблокирующегося sendfile() событие должно
> было бы прийти :) Похожая ситуация и с rtsig. С poll и select всё
> работает как и ожидалось.
rtsig - edge triggered by design.
poll and select - level triggered by design.
> для себя цитата из man epoll
> The suggested way to use epoll as an Edge Triggered ( EPOLLET )
> interface is below, and possible pitfalls to avoid follow.
> i with non-blocking file descriptors
> ii by going to wait for an event only after read(2) or write(2)
> return EAGAIN
>
> вот как раз и получаем что при полном sendfile не имеем EAGAIN и не
> имеем события.
write и sendfile могут вернуть меньше, чем их просили.
EAGAIN возвращается, если даже один байт записать некуда.
--
Игорь Сысоев
http://sysoev.ru