ПРОЕКТЫ 


  АРХИВ 


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: Сбор статистики о файле



Спасибо, работает.

Единственно что - я не придумал ничего лучше чем вставить регистрацию
cleanup процедуры в фильтр тела ответа, по флагу. Я не нашёл способа,
как получить request_t где-нибудь в инциализации или создании conf.
Может есть лучшее место?
-------
     if (!conf->is_finish_inited)
     {
          cln = ngx_http_cleanup_add(r, 0);
          if (cln == NULL) {
              ngx_http_finalize_request(r, NGX_HTTP_INTERNAL_SERVER_ERROR);
              return NGX_ERROR;
          }

          cln->handler = ngx_http_request_stats_cleanup;
          cln->data = r;
          conf->is_finish_inited = 1;
     }
----------
И ещё вопрос - у cleanup процедуры есть какие-либо обязательства? Т.е.
там нужно вызывать цепочку дальше, или нет? Если нужно, то где взять
статус завершения, для вызова ngx_http_finalize_request?

On 4/17/06, Igor Sysoev <is@xxxxxxxxxxxxx> wrote:
> On Mon, 17 Apr 2006, ForJest wrote:
>
> > Я почти дописал модуль, для сбора статистики. У меня возник вопрос -
> > как отследить в модуле завершение обработки запроса?
> > Отсылку headers понятно, части отсылки тела ответа - тоже. А вот как
> > отследить завершение? Или цепочка будет вызвана и в случае
> > преждевременного завершения запроса тоже?
>
> Нужно зарегистировать cleanup процедуру:
>
>     cln = ngx_http_cleanup_add(r, 0);
>     if (cln == NULL) {
>        ...
>     }
>
>     cln->handler = ngx_http_module_cleanup;
>     cln->data = r;
>
> на примере ngx_http_upstream.c. Эта процедура вызвается по окончании
> обработки запроса.
>
>
> Игорь Сысоев
> http://sysoev.ru
>
>


 




Copyright © Lexa Software, 1996-2009.