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
|