ПРОЕКТЫ 


  АРХИВ 


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]

фильтр дублирует ответы


  • To: nginx-ru@xxxxxxxxx
  • Subject: фильтр дублирует ответы
  • From: "o1egus" <nginx-forum@xxxxxxxx>
  • Date: Tue, 01 Jun 2010 04:03:20 -0400
  • Dkim-signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=mickey.jlkhosting.com; s=x; h=Sender:From:Message-ID:Content-Transfer-Encoding:Content-Type:Subject:To:Date; bh=dt2WfMGvr2Yl0OuTIv/kjkxihV5StxC0nYtd+F7e6wE=; b=Bz4iIxjL1PSqV/hyMc9Q2CJnkjs+8AhmH07xIOSZzcSp/oxPpe1+FoalV6OiqfUVT9u1gGoZBkwDx/mMmf5PoNR0dmxqcU8fngLEG0UpIWCDNd65pw85X58Sp5x5Su6R;

Привет.

Написал простой фильтр для nginx. 
nginx фронтенд(localhost:8000). apache бэкенд(localhost:80).

Код фильтра.
[code]
#include "pg.h"

#include <ngx_config.h>
#include <ngx_core.h>
#include <ngx_http.h>

static ngx_int_t ngx_http_pg_filter_init(ngx_conf_t *cf);
static ngx_int_t ngx_http_pg_header_filter(ngx_http_request_t *r);
static ngx_int_t ngx_http_pg_body_filter(ngx_http_request_t *r, ngx_chain_t 
*in);

static ngx_http_module_t  ngx_http_pg_module_ctx = {
    NULL,                          /* preconfiguration */
    ngx_http_pg_filter_init,       /* postconfiguration */

    NULL,                          /* create main configuration */
    NULL,                          /* init main configuration */

    NULL,                          /* create server configuration */
    NULL,                          /* merge server configuration */

    NULL,                                                  /* create location 
configuration */
    NULL                                                   /* merge location 
configuration */
};

ngx_module_t  ngx_http_pg_module = {
    NGX_MODULE_V1,
    &ngx_http_pg_module_ctx,       /* module context */
    NULL,                  /* module directives */
    NGX_HTTP_MODULE,               /* module type */
    NULL,                          /* init master */
    NULL,                          /* init module */
    NULL,                          /* init process */
    NULL,                          /* init thread */
    NULL,                          /* exit thread */
    NULL,                          /* exit process */
    NULL,                          /* exit master */
    NGX_MODULE_V1_PADDING
};

static ngx_http_output_header_filter_pt  ngx_http_next_header_filter;
static ngx_http_output_body_filter_pt    ngx_http_next_body_filter;

static ngx_int_t ngx_http_pg_header_filter(ngx_http_request_t *r)
{

        return ngx_http_next_header_filter(r);
}

static ngx_int_t ngx_http_pg_body_filter(ngx_http_request_t *r, ngx_chain_t 
*in) {

        if(in == NULL || r->header_only)
                return ngx_http_next_body_filter(r, in);
        ngx_log_error(NGX_LOG_ERR, r->connection->log, 0,"buf_size:%d", 
ngx_buf_size(in->buf));
        ngx_log_error(NGX_LOG_ERR, r->connection->log, 0,"status:%d", 
r->headers_out.status);
        return ngx_http_next_body_filter(r, in);
}

static ngx_int_t ngx_http_pg_filter_init(ngx_conf_t *cf) {
    ngx_http_next_header_filter = ngx_http_top_header_filter;
    ngx_http_top_header_filter = ngx_http_pg_header_filter;

    ngx_http_next_body_filter = ngx_http_top_body_filter;
    ngx_http_top_body_filter = ngx_http_pg_body_filter;

    return NGX_OK;
}
[/code]

Файл nginx.conf
[code]
daemon off;

worker_processes  1;

events {
    worker_connections  1024;
}

http {
    include       mime.types;
    default_type  application/octet-stream;

    keepalive_timeout  0;

    server {

        listen       8000;
        server_name  localhost;
        
        location / {
                proxy_pass http://localhost:80;
        }
    }
}
[/code]

В браузере шлю запрос http://localhost:8000/1.html.

1.html выглядит так:
[code]
HELLO
[/code]

Получаю в error.log
[code]
#нормальный ответ
2010/06/01 14:54:15 [error] 11576#0: *1 buf_size:5 while sending to client, 
client: 127.0.0.1, server: localhost, request: "GET /1.html HTTP/1.1", 
upstream: "http://127.0.0.1:80/1.html";, host: "localhost:8000"
2010/06/01 14:54:15 [error] 11576#0: *1 status:200 while sending to client, 
client: 127.0.0.1, server: localhost, request: "GET /1.html HTTP/1.1", 
upstream: "http://127.0.0.1:80/1.html";, host: "localhost:8000"

#повторный ответ с пустым буфером
2010/06/01 14:54:15 [error] 11576#0: *1 [b]buf_size:0[/b] while sending to 
client, client: 127.0.0.1, server: localhost, request: "GET /1.html HTTP/1.1", 
upstream: "http://127.0.0.1:80/1.html";, host: "localhost:8000"
2010/06/01 14:54:15 [error] 11576#0: *1 status:200 while sending to client, 
client: 127.0.0.1, server: localhost, request: "GET /1.html HTTP/1.1", 
upstream: "http://127.0.0.1:80/1.html";, host: "localhost:8000"


#нормальный ответ
2010/06/01 14:54:15 [error] 11576#0: *3 buf_size:283 while sending to client, 
client: 127.0.0.1, server: localhost, request: "GET /favicon.ico HTTP/1.1", 
upstream: "http://127.0.0.1:80/favicon.ico";, host: "localhost:8000"
2010/06/01 14:54:15 [error] 11576#0: *3 status:404 while sending to client, 
client: 127.0.0.1, server: localhost, request: "GET /favicon.ico HTTP/1.1", 
upstream: "http://127.0.0.1:80/favicon.ico";, host: "localhost:8000"

#повторный ответ с пустым буфером
2010/06/01 14:54:15 [error] 11576#0: *3 [b]buf_size:0[/b] while sending to 
client, client: 127.0.0.1, server: localhost, request: "GET /favicon.ico 
HTTP/1.1", upstream: "http://127.0.0.1:80/favicon.ico";, host: "localhost:8000"
2010/06/01 14:54:15 [error] 11576#0: *3 status:404 while sending to client, 
client: 127.0.0.1, server: localhost, request: "GET /favicon.ico HTTP/1.1", 
upstream: "http://127.0.0.1:80/favicon.ico";, host: "localhost:8000"
[/code]

Откуда берется повторный ответ с пустым буфером?

Posted at Nginx Forum: http://forum.nginx.org/read.php?21,93023,93023#msg-93023


_______________________________________________
nginx-ru mailing list
nginx-ru@xxxxxxxxx
http://nginx.org/mailman/listinfo/nginx-ru


 




Copyright © Lexa Software, 1996-2009.