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;
}
}
}