Re: BugReport: ./configure --add-module неправильно подключает filter модуль

Denis Erygin erygin at corp.mail.ru
Fri Jun 8 12:22:50 MSD 2007


Нужно ли читать буфер своими силами когда
инициализирован file и  in_file = 1 ?

Например в ngx_http_*_body_filter ( ngx_http_request_t* r, ngx_chain_t* in )
пришло:

in->buf->pos = NULL
in->buf->last = NULL
in->buf->start = NULL
in->buf->end = NULL
in->buf->in_file = 1
in->buf->last_buf = 1
in->buf->last_in_chain = 1
...

В таком случае нужно брать дескриптор файла из in->buf->file и из него 
читать?
Но я такого в готовых фильтрах не нашел.

Еще насчет контекстов:

static ngx_int_t ngx_http_my_header_filter ( ngx_http_request_t* r )
{
       ngx_http_my_ctx_t* ctx;

       if ( r != r->main )  return ngx_http_next_header_filter (r);

       ctx = ngx_pcalloc(r->pool, sizeof(ngx_http_my_ctx_t));
       if (ctx == NULL) return NGX_ERROR;

       // Устанавливаем фактически только для r->main
       ngx_http_set_ctx ( r, ctx, ngx_http_my_filter_module);

       return ngx_http_next_header_filter (r);
}

static ngx_int_t ngx_http_tmpl_body_filter ( ngx_http_request_t* r, 
ngx_chain_t* in )
{
      ngx_http_my_ctx_t* ctx;
      ....
      ctx = ngx_http_get_module_ctx ( r, ngx_http_my_filter_module );
      if ( ctx == NULL ) 
<= // Не срабатывает для r != r->main
           return ngx_http_next_body_filter ( r, in );
      ....
      return ngx_http_next_body_filter ( r, in );
}

В тестах ngx_http_tmpl_body_filter(...)  сtx != NULL даже когда r != 
r->main,
хотя контекст был установлен только для r->main.

----- Original Message ----- 
From: "Igor Sysoev" <is at rambler-co.ru>
To: <nginx-ru at sysoev.ru>
Sent: Thursday, June 07, 2007 10:41 PM
Subject: Re: BugReport: ./configure --add-module неправильно подключает 
filter модуль


On Thu, Jun 07, 2007 at 10:12:44PM +0400, Denis Erygin wrote:

> >А как там может возникнуть зацикливание ?
>
> Я имею ввиду то, что если в ngx_http_*_body_filter()
> вызвать ngx_http_subrequest, то сервер войдет в цикл,
> который прервется в конце концов core дампом (проверено).
>
> В ngx_http_ssi_body_filter же используется специальная обработка,
> предупреждающая повторный вызов ngx_http_subrequest в результате
> работы предыдущего ngx_http_subrequest, которая мне не совсем понятна.

В ngx_http_ssi_body_filter ngx_http_subrequest() вызывается не от балды,
а когда в потоке встречается include. Если при парсинге ответа подзапроса
не будет найден include, то и ngx_http_subrequest() вызываться не будет.

> >Контекст выставляется для каждого подзапроса. Вся обработка ssi хранится
> >в контексте.
> Т.е. не могу создать в контексте счетчик вызовов ngx_http_*_body_filter()
> /ngx_http_subrequest,
> т.к. сам контекст целиком постоянно обновляется?
>
> Я бы хотел реализовать логику паттерна singleton для вызова
> ngx_http_subrequest из
> ngx_http_*_body_filter(), для этого нужен счетчик этих вызовов, чтобы
> отличить основной
> вызов ngx_http_*_body_filter() от пришедшего ответа к ngx_http_subrequest
> (который также вызовет ngx_http_*_body_filter() ) - вот собственно и все..
> Конечно, можно завести глобальную переменную, но 
> ngx_http_ssi_filter_module
> такой подход не использует, вот и возникает вопрос, что там происходит.

Потому что в ngx_http_ssi_filter_module нет глобального контекста - ему
нечего там хранить. Зато есть сотни одновременных контекстов, связанных
с запросами.

Основной запрос от подзапроса отличается так:

основной:  r == r->main
подзапрос: r != r->main

> Пусть будет общий для всего модуля ngx_http_*_body_filter,
> нужно отличить контекст его вызова для обычного запроса от ответа к
> ngx_http_subrequest,
> разбор исходников пока четкого ответа не дал.
>
> ----- Original Message ----- 
> From: "Igor Sysoev" <is at rambler-co.ru>
> To: <nginx-ru at sysoev.ru>
> Sent: Thursday, June 07, 2007 7:57 PM
> Subject: Re: BugReport: ./configure --add-module неправильно подключает
> filter модуль
>
>
> On Thu, Jun 07, 2007 at 06:30:07PM +0400, Denis Erygin wrote:
>
> >Какой механизм используется для блокирования зацикливания
> >по ngx_http_subrequest в ngx_http_ssi_filter_module?
>
> А как там может возникнуть зацикливание ?
>
> >Насколько я понял, эмулируется сессия с помощью:
> >ngx_http_get_module_ctx ( r, ngx_http_ssi_filter_module );
> >ngx_http_set_ctx ( r, ctx, ngx_http_ssi_filter_module );
> >
> >Но я столкнулся с тем, что первый параметр "r" (ngx_http_request_t)
> >в ngx_http_ssi_body_filter меняется после вызова ngx_http_subrequest,
> >и ngx_http_get_module_ctx возвращает NULL, даже если заранее
> >инициализировать через ngx_http_set_ctx  в ngx_http_ssi_header_filter.
> >
> >Как это работает в ngx_http_ssi_filter_module?
>
> Контекст выставляется для каждого подзапроса. Вся обработка ssi хранится
> в контексте.
>
>
> -- 
> Игорь Сысоев
> http://sysoev.ru
>
>

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






More information about the nginx-ru mailing list