Welcome! Log In Create A New Profile

Advanced

Закрытие соединения: nginx возвращает в заголовке "Connection : close"

August 22, 2013 08:06AM
Всем, привет !
Я уже поднимал данную проблему, но решил создать еще один топик с полной информацией.
Итак, NGINX:

nginx version: nginx/1.4.1
built by gcc 4.1.2 20080704 (Red Hat 4.1.2-54)
TLS SNI support disabled
configure arguments: --user=nginx --group=nginx --prefix=/usr/share/nginx --sbin-path=/usr/sbin/nginx --conf-path=/etc/nginx/nginx.conf --error-log-path=/var/log/nginx/error.log --http-log-path=/var/log/nginx/access.log --http-client-body-temp-path=/var/lib/nginx/tmp/client_body --http-proxy-temp-path=/var/lib/nginx/tmp/proxy --http-fastcgi-temp-path=/var/lib/nginx/tmp/fastcgi --pid-path=/var/run/nginx.pid --lock-path=/var/lock/subsys/nginx --with-http_secure_link_module --with-http_random_index_module --with-http_ssl_module --with-http_realip_module --with-http_addition_module --with-http_sub_module --with-http_dav_module --with-http_flv_module --with-http_gzip_static_module --with-http_stub_status_module --with-http_perl_module --with-http_xslt_module --with-debug --with-mail --with-mail_ssl_module --with-cc-opt='-O2 -g -m64 -mtune=generic' --with-ipv6 --add-module=/usr/src/redhat/BUILD/nginx-1.4.1/nginx-upstream-fair --add-module=/usr/src/redhat/BUILD/nginx-1.4.1/nginx-upload-progress-module --add-module=/usr/src/redhat/BUILD/nginx-1.4.1/mod_zip --add-module=/usr/src/redhat/BUILD/nginx-1.4.1/nginx_mod_h264_streaming --add-module=/usr/src/redhat/BUILD/nginx-1.4.1/nginx-push-stream-module --add-module=/usr/src/redhat/BUILD/nginx-1.4.1/nginx_upstream_hash --add-module=/usr/src/redhat/BUILD/nginx-1.4.1/nginx-memcached-hash-pass --add-module=/usr/src/redhat/BUILD/nginx-1.4.1/echo-nginx-module --add-module=/usr/src/redhat/BUILD/nginx-1.4.1/ngx_http_gunzip_filter_module --add-module=/usr/src/redhat/BUILD/nginx-1.4.1/headers-more-nginx-module


Есть back-end (JBOSS) и front-end (NGINX). На nginx настроено проксирование и включен keep-alive:

http{
...
keepalive_timeout 45 45;
keepalive_requests 1000;
...
}

...

server{
...
location /our-portal/ {
proxy_pass http://127.0.0.1:8080;
break;
error_page 404 = @404;
error_page 502 = @502;
error_page 504 = @504;
}
...
}

если дергать нужный мне ресурс напрямую с back-end(JBOSS), то приходит следующий заголовок:

Заголовок ответа:
---------------------------------------------------------------
Accept-Ranges bytes
Cache-Control no-cache
Content-Type application/x-javascript; charset=UTF-8
Date Thu, 22 Aug 2013 11:46:04 GMT, Thu, 22 Aug 2013 11:46:04 GMT
Server Restlet-Framework/2.0.14
Transfer-Encoding chunked
Vary Accept-Charset, Accept-Encoding, Accept-Language, Accept
---------------------------------------------------------------

Если делать запрос через front-end, то NGINX возвращает следующее:
---------------------------------------------------------------
Cache-Control no-cache
Connection close
Content-Encoding gzip
Content-Type application/x-javascript; charset=UTF-8
Date Thu, 22 Aug 2013 11:45:25 GMT
Server nginx
Vary Accept-Encoding, Accept-Charset, Accept-Encoding, Accept-Language, Accept
---------------------------------------------------------------

Как видно из последнего запроса, nginx шлет ответ клиенту и не позволяет переиспользовать имеющийся коннекшн, присылая "Connection : close". Это касается всех ресурсов, которые запрашивает nginx c back-end.
Если ресурс на nginx не пробрасывается на прокси или данные берутся из memcached (подключен соответсвующий модуль), то nginx исправно присылает "Connection : keep-alive".
Как побороть данную проблему ? Как заставить nginx возвращать keep-alive соединения клиенту при получении данных с прокси ?

Есть предположение, что он это делает, поскольку данные - динамические, и nginx не знает размер данных, отдаваемых клиенту, и для страховки запрещает переиспользовать соединение, по которому передаются данные неизвестного размера. Были мысли, чтобы nginx буферизировал данные с прокси, а потом проставлял размер ответа и возвращал keep-alive (не врядли это возможно). С другой стороны согласно документации Http-1.1 позволяет использовать keep-alive совместно с chunked.

Есть какие-то мысли относительно данной проблемы ?
Заранее благодарю всех, кто откликнется!
Subject Author Posted

Закрытие соединения: nginx возвращает в заголовке "Connection : close"

aler August 22, 2013 08:06AM

Re: Закрытие соединения: nginx возвращает в заголовке "Connection : close"

Sov1et August 22, 2013 08:12AM

Re: Закрытие соединения: nginx возвращает в заголовке "Connection : close"

aler August 22, 2013 08:18AM

Re: Закрытие соединения: nginx возвращает в заголовке "Connection : close"

Maxim Dounin August 22, 2013 08:22AM

Re: Закрытие соединения: nginx возвращает в заголовке "Connection : close"

aler August 22, 2013 08:34AM

Re: Закрытие соединения: nginx возвращает в заголовке "Connection : close"

Maxim Dounin August 22, 2013 09:10AM

Re: Закрытие соединения: nginx возвращает в заголовке "Connection : close"

aler August 23, 2013 02:34AM



Sorry, only registered users may post in this forum.

Click here to login

Online Users

Guests: 173
Record Number of Users: 8 on April 13, 2023
Record Number of Guests: 421 on December 02, 2018
Powered by nginx      Powered by FreeBSD      PHP Powered      Powered by MariaDB      ipv6 ready