ПРОЕКТЫ 


  АРХИВ 


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: Неблокирующее чтение фа йла в модуле



Естественным решением было бы написать фильтр, который встанет в цепь фильтров 
до copy filter. Этот фильтр добавит буфер, указывающий на необходимый Вам файл. 
copy filter загрузит файл в память наилучшим образом, после чего любой другой 
фильтр получит доступ к содержимому этого файла в памяти.

Если с данными файла нужно выполнить какие-нибудь манипуляции, то, возможно, 
потребуется второй фильтр. Логику работы вторго фильтра добавить по вкусу:

1) Отсчитать необходимое число байт от начала потока (альтернатива -- от конца);
2) Использовать escape-последовательности: <!--# myfile <содержимое файла> -->

----- Валентин Бартенев <ne@xxxxxxxx> wrote:
> Пишу модуль-фильтр для nginx и мне необходимо прочитать файл.
> 
> Как лучше это сделать?
> 
> Я догадываюсь, что мою задачу можно решить с помощью ngx_http_subrequest, но 
> мне бы не хотелось его использовать, мне кажется это порождает слишком много 
> излишних накладных расходов, а мне нужно всего-то поместить содержимое 
> двоичного файла в один большой буфер. Типичный размер файлов с которыми я 
> буду 
> иметь дело 50-200 Кб.
> 
> Если не ngx_http_subrequest, то какие еще есть способы, чтобы не 
> заблокировать 
> процесс? Я подозреваю, что мне нужно копать в сторону aio и добавления 
> events. 
> Но некоторое количество подсказок бы мне сильно облегчили жизнь...

-- 
Regards,
Valery Kholodkov
_______________________________________________
nginx-ru mailing list
nginx-ru@xxxxxxxxx
http://nginx.org/mailman/listinfo/nginx-ru


 




Copyright © Lexa Software, 1996-2009.