
Tenho procurado em todos os lugares para descobrir por que meu servidor nginx está causando um redirecionamento 301 em um domínio e não no outro. Tenho dois sites configurados neste servidor no estilo apache (sites disponíveis). Digamos domínio1.com e domínio2.com. Estou executando o PHP-FPM também. Aqui estão as configurações
Domínio1.com
server {
listen 80; ## listen for ipv4; this line is default and implied
server_name domain1.com www.domain1.com;
root /var/www/domain1.com;
index index.php index.html index.htm;
location / {
try_files $uri $uri/ /index.php?$args;
}
#error_page 404 /404.html;
# redirect server error pages to the static page /50x.html
#
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root /usr/share/nginx/www;
}
# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
#
location ~ \.php$ {
try_files $uri =404;
fastcgi_pass unix:/var/run/php5-fpm.sock;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
# deny access to .htaccess files, if Apache's document root
# concurs with nginx's one
#
location ~ /\.ht {
deny all;
}
}
Domínio2.com
server {
listen 80; ## listen for ipv4; this line is default and implied
server_name domain2.com www.domain2.com;
root /home/mike/www;
index index.php index.html index.htm;
location / {
try_files $uri $uri/ /index.php?$args;
}
#error_page 404 /404.html;
# redirect server error pages to the static page /50x.html
#
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root /usr/share/nginx/www;
}
# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
#
location ~ \.php$ {
try_files $uri =404;
fastcgi_pass unix:/var/run/php5-fpm.sock;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
# deny access to .htaccess files, if Apache's document root
# concurs with nginx's one
#
location ~ /\.ht {
deny all;
}
}
Você notará que eles são basicamente iguais, exceto server_name e root. Caso contrário, eles são idênticos. Agora aqui está a situação. domain1.com funciona bem, sem problemas. O site do domínio2 foi testado UMA VEZ usando listen 8000 quando o DNS do domínio2.com não foi alterado para o servidor. Quando foi testado como IP:8000, funcionou bem, então mudei para o domínio, mudei a porta para 80 e mudei o DNS. Desde então, o servidor foi completamente desligado e o nginx e o php5-fpm foram reiniciados provavelmente 100 vezes.
Se eu visitar domain2.com no navegador, ele redirecionará automaticamente para domain2.com:8000. Se eu usar web-sniffer.net e observar o cabeçalho HTTP, ele retornará um redirecionamento 301. Eu nunca configurei um redirecionamento e não há configuração 301 em nenhum lugar deste servidor. O que realmente me incomoda é que se eu visitar www.domain2.com, depois de removê-lo do arquivo de configuração nginx em server_name, vejo a página nginx padrão, o que significa que está funcionando bem. Depois de adicionar www.domain2.com à diretiva server_name na configuração, o redirecionamento 301 inicia novamente.
Eu adicionei port_in_redirect off na seção http em meu nginx.conf também, o que parece não fazer nada.
Alguém tem alguma ideia do que está acontecendo aqui?
Editar: curl-vhttp://domínio2.com
* About to connect() to domain2.com port 80 (#0)
* Trying 162.243.XXX.XXX... connected
> GET / HTTP/1.1
> User-Agent: curl/7.22.0 (x86_64-pc-linux-gnu) libcurl/7.22.0 OpenSSL/1.0.1 zlib/1.2.3.4 libidn/1.23 librtmp/2.3
> Host: domain2.com
> Accept: */*
>
< HTTP/1.1 301 Moved Permanently
< Server: nginx/1.1.19
< Date: Mon, 13 Jan 2014 17:37:07 GMT
< Content-Type: text/html; charset=UTF-8
< Transfer-Encoding: chunked
< Connection: keep-alive
< X-Powered-By: PHP/5.3.10-1ubuntu3.9
< X-Pingback: http://162.243.XXX.XXX:8000/xmlrpc.php
< Location: http://domain2.com:8000/
<
* Connection #0 to host domain2.com left intact
* Closing connection #0
Responder1
É um pouco difícil adivinhar sem ver a saída real do servidor. Sugiro usar curl -v http://example2.com/
para ver o que realmente é retornado, mas acho que seu navegador armazenou o redirecionamento em cache. Eu já vi isso antes.
Usar um navegador diferente mostra o mesmo redirecionamento?
Atualizar: De acordo com sua saída de diagnóstico, parece claro que isso foi causado pelo Wordpress emitindo o redirecionamento, em vez de nginx
.