nginx infinite 302 Encontrado loop de redirecionamento

2

Estou usando o nginx para mapear vários domínios para o mecanismo de aplicativos do Google. Neste caso específico, mapeio vários domínios para o mesmo locatário . existe uma configuração no meu código que sabe qual domínio é o domínio principal e quando uma solicitação chega, eu verifico se o host é o domínio principal e se não for redirecionado para o domínio principal.

por exemplo, digamos que www.aaa.com é o domínio definido como padrão

aaa.com     -> www.aaa.com
www.bbb.com -> www.aaa.com
ccc.com     -> www.aaa.com
...

O que acontece aleatoriamente de tempos em tempos é que um URL javascript entra em um loop de redirecionamento no nginx. Observe que a solicitação nunca atinge o appengine. O nginx está criando esse loop 302 Found . isso aconteceu 2 vezes nas últimas 2 semanas.

o caminho da solicitação é semelhante a www.aaa.com/22/foobar.js , em que a primeira parte do caminho é o número da versão do arquivo javascript.

um arquivo css com o mesmo formato uri www.aaa.com/22/foobar.css não terá esse loop de redirecionamento.

se eu implantar uma nova versão, o arquivo será servidor corretamente novamente. portanto, implantar uma versão 23 e acessar www.aaa.com/23/foobar.js funcionaria novamente. também se eu usar um cachebuster na solicitação como www.aaa.com/22/foobar.js?345 reiniciar o nginx ou mesmo reiniciar a máquina onde o nginx está em execução não ajuda. configurar uma nova máquina com a mesma configuração exata serve ao arquivo sem nenhum problema.

Então, o que poderia causar esse loop de redirecionamento? Como eu poderia me livrar disso uma vez que isso acontece? existe um cache no nginx (eu sei nginx não é o cache por padrão) eu não sei sobre? a máquina pode armazenar em cache esses redirecionamentos?

aqui meu nginx.conf

user nginx;
worker_processes 2;
error_log /var/log/nginx/error.log;
pid /var/run/nginx.pid;
events {
    worker_connections 1024;
}

http {
    include /etc/nginx/mime.types;
    default_type application/octet-stream;
    server_names_hash_max_size 1024;
    server_names_hash_bucket_size 128;
    log_format main '$remote_addr - $remote_user [$time_local] "$request" '
                    '$status $body_bytes_sent "$http_referer" '
                    '"$http_user_agent" "$http_x_forwarded_for"';

    access_log /var/log/nginx/access.log main;
    sendfile on;

    keepalive_timeout 65;
    # enable gzip compression
    gzip on;
    gzip_min_length 1100;
    gzip_buffers 4 32k;
    gzip_comp_level 5;
    gzip_types text/plain application/x-javascript text/xml text/css;
    gzip_vary on;


    server {
        server_name www.aaa.com;

        location / {
            resolver 8.8.8.8;
            proxy_pass http://tenantname.myappid.appspot.com/$request_uri;
            proxy_set_header Host tenantname.myappid.appspot.com;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header NexHost $scheme://$host;
            proxy_redirect http://tenantname.myappid.appspot.com/ /;
            proxy_intercept_errors on;
        }
    }


    server {
        server_name aaa.com;

        location / {
            resolver 8.8.8.8;
            proxy_pass http://tenantname.myappid.appspot.com/$request_uri;
            proxy_set_header Host tenantname.myappid.appspot.com;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header NexHost $scheme://$host;
            proxy_redirect http://tenantname.myappid.appspot.com/ /;
            proxy_intercept_errors on;
        }
    }

    server {
        server_name www.bbb.com;

        location / {
            resolver 8.8.8.8;
            proxy_pass http://tenantname.myappid.appspot.com/$request_uri;
            proxy_set_header Host tenantname.myappid.appspot.com;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header NexHost $scheme://$host;
            proxy_redirect http://tenantname.myappid.appspot.com/ /;
            proxy_intercept_errors on;
        }
    }



    server {
        server_name bbb.com;

        location / {
            resolver 8.8.8.8;
            proxy_pass http://tenantname.myappid.appspot.com/$request_uri;
            proxy_set_header Host tenantname.myappid.appspot.com;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header NexHost $scheme://$host;
            proxy_redirect http://tenantname.myappid.appspot.com/ /;
            proxy_intercept_errors on;
        }
    }



    server {
        server_name www.ccc.com;

        location / {
            resolver 8.8.8.8;
            proxy_pass http://tenantname.myappid.appspot.com/$request_uri;
            proxy_set_header Host tenantname.myappid.appspot.com;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header NexHost $scheme://$host;
            proxy_redirect http://tenantname.myappid.appspot.com/ /;
            proxy_intercept_errors on;
        }
    }


    server {
        server_name ccc.com;

        location / {
            resolver 8.8.8.8;
            proxy_pass http://tenantname.myappid.appspot.com/$request_uri;
            proxy_set_header Host tenantname.myappid.appspot.com;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header NexHost $scheme://$host;
            proxy_redirect http://tenantname.myappid.appspot.com/ /;
            proxy_intercept_errors on;
        }
    }


    server {
        server_name ~^(?<sub>.+)\.maindomain\.com$;

        location / {
            resolver 8.8.8.8;
            proxy_pass http://$sub.myappid.appspot.com/$request_uri;
            proxy_set_header Host $sub.myappid.appspot.com;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header NexHost $scheme://$host;
            proxy_redirect http://$sub.myappid.appspot.com/ /;
            proxy_intercept_errors on;
        }
    }

    server {
        listen 80 default_server;
        server_name _;
        location / {
            root /etc/nginx/html;
        }
    }
}
    
por aschmid00 09.04.2014 / 17:26

1 resposta

1

então resolvi esse problema redirecionando do nginx ao invés do backend.
enquanto o problema está resolvido até agora eu ainda não descobri por que esse loop de redirecionamento estava acontecendo em primeiro lugar.

todas as sugestões seriam úteis.

    
por 14.04.2014 / 17:44