Re: Возможно ли использовать nginx как туннель с кешированием статики и websockets

tao nginx-forum at nginx.us
Wed Jul 3 10:41:40 UTC 2013


Забыл указать nginx 

nginx version: nginx/1.4.1
built by gcc 4.4.7 20120313 (Red Hat 4.4.7-3) (GCC) 
TLS SNI support enabled
configure arguments: 
--prefix=/etc/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 
--pid-path=/var/run/nginx.pid 
--lock-path=/var/run/nginx.lock 
--http-client-body-temp-path=/var/cache/nginx/client_temp 
--http-proxy-temp-path=/var/cache/nginx/proxy_temp 
--http-fastcgi-temp-path=/var/cache/nginx/fastcgi_temp 
--http-uwsgi-temp-path=/var/cache/nginx/uwsgi_temp 
--http-scgi-temp-path=/var/cache/nginx/scgi_temp 
--user=nginx 
--group=nginx 
--with-http_ssl_module 
--with-http_realip_module 
--with-http_addition_module 
--with-http_sub_module 
--with-http_gunzip_module 
--with-http_gzip_static_module 
--with-http_secure_link_module 
--with-http_stub_status_module 
--with-mail 
--with-mail_ssl_module 
--with-file-aio 
--with-ipv6 
--with-cc-opt='-O2 -g -pipe -Wall -Wp,-D_FORTIFY_SOURCE=2 -fexceptions
-fstack-protector 
--param=ssp-buffer-size=4 -m64 -mtune=generic' 
--add-module=/home/builder/rpmbuild/SOURCES/ngx_devel_kit 
--add-module=/home/builder/rpmbuild/SOURCES/redis2-nginx-module 
--add-module=/home/builder/rpmbuild/SOURCES/set-misc-nginx-module 
--add-module=/home/builder/rpmbuild/SOURCES/lua-nginx-module 
--add-module=/home/builder/rpmbuild/SOURCES/echo-nginx-module 
--add-module=/home/builder/rpmbuild/SOURCES/nginx-rtmp-module


tao Wrote:
-------------------------------------------------------
> в браузере-клиенте (chrome) прописан ip http proxy (nginx) 
> на домене club по 3000 порту висит socket.io с поддержкой xhr-pooling
> и websockets и nginx для отдачи статики по 80 порту
> все хорошо и отлично кешируется c 80 порта, xhr-pooling  тоже работает
> отлично
> 
> Но как только переключаюсь на websockets  , получаю в логи
> ==
> [ 03/Jul/2013:11:50:17 +0400 ] -  "CONNECT club:3000 HTTP/1.1" "400"
> "rt:0.018" "urt:-" "cache: -" 
> 
> 
> 
> ==== CONFIG
> map $http_upgrade $connection_upgrade {
>         default upgrade;
>         ''      close;
> }
> 
> upstream club_80        {    server club:80;}
> upstream club_3000      {    server club:3000;}
> 
> server {
> 
>     listen 8090;
>     server_name _;
>     access_log /var/log/nginx/proxy.8090.access.log common;
>     error_log  /var/log/nginx/proxy.8090.error.log;
> 
>     source_charset utf-8;
>     charset        utf-8;
> 
>     recursive_error_pages on;
> 
>     #upstream mapping
>     set $xport 80;
>     if ($http_host ~ ":(\d+)") { set $xport $1; }
>     set $upstr "club_${xport}";
> 
> 
>     error_page 417 = @cached;
>     error_page 418 = @nocached;
>     
>     proxy_http_version 1.1;
>     proxy_set_header        Upgrade         $http_upgrade;
>     proxy_set_header        Connection      $connection_upgrade;
> 
>     proxy_buffering off;
>     
>     location / {
> 
>         return 417;
>     }
>    location /socket.io {
>         
>         return 418;
>     }
>     
>     location ~ /(ru|en/)?index.html {
> 
>         return 418;
>     }
>             
>     #for index/socket.io
>     location @nocached {
>         proxy_read_timeout 86400;
>         proxy_cache     off;
>         proxy_pass      http://$upstr;
>         proxy_set_header        Host            $host;
>         proxy_set_header        X-Forwarded-For
> $proxy_add_x_forwarded_for;
>         add_header              Cache-Control  
> "no-cache,no-store,must-revalidate";
>         expires -1;
>     }
>         
>     #for static
>     location @cached {
>     
>         proxy_cache_methods GET;
>         proxy_cache_valid 200 5d;
>         proxy_cache clubcache;
>         proxy_pass      http://$upstr;
>         proxy_set_header        Host            $host:$proxy_port;
>         proxy_set_header        X-Forwarded-For
> $proxy_add_x_forwarded_for;
> 
>         proxy_cache_bypass      $cookie_nocache
> $arg_nocache$arg_comment;
>         proxy_cache_bypass      $http_pragma    $http_authorization;
> 
>         proxy_ignore_headers    X-Accel-Expires Expires Cache-Control
> Set-Cookie;
> 
>         add_header Cache-Control "no-cache,no-store,must-revalidate";
>         expires -1;
> 
>     }
> }
> ================= END

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



Подробная информация о списке рассылки nginx-ru