nginx 400 Solicitud incorrecta (nombre de host no válido)

nginx 400 Solicitud incorrecta (nombre de host no válido)

Configuré nginx como un equilibrador de carga de front-end en tres nodos de una aplicación web que construí. nginx devuelve continuamente 400/solicitud incorrecta: errores de nombre de host no válidos, independientemente de los valores que uso en upstream.server y server.server_name. Probé localhost y 127.0.0.1 para ambos valores y envié solicitudes utilizando solicitudes coincidentes de cURL/Postman sin éxito.

También intenté configurar el valor de server.server_name, incluido el número de puerto, para que coincida mejor con el encabezado HTTP HOST entrante, sin éxito.

nginx.conf

events {
  worker_connections  1024; 
}

http { 
  upstream myapp {
    server 127.0.0.1:8001;
    server 127.0.0.1:8002;
    server 127.0.0.1:8003;
  }

  server {
    listen 8000;
    server_name 127.0.0.1;
    location / {
      proxy_pass http://myapp;
    }
  }
}

Las solicitudes de cURL dan como resultado lo siguiente (no hay diferencia entre usar localhost y 127.0.0.1).

C:\>curl -v http://127.0.0.1:8000/
*   Trying 127.0.0.1...
* TCP_NODELAY set
* Connected to 127.0.0.1 (127.0.0.1) port 8000 (#0)
> GET / HTTP/1.1
> Host: 127.0.0.1:8000
> User-Agent: curl/7.55.1
> Accept: */*
>
< HTTP/1.1 400 Bad Request
< Server: nginx/1.17.1
< Date: Mon, 22 Jul 2019 14:29:22 GMT
< Content-Type: text/html; charset=us-ascii
< Content-Length: 334
< Connection: keep-alive
<
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN""http://www.w3.org/TR/html4/strict.dtd">
<HTML><HEAD><TITLE>Bad Request</TITLE>
<META HTTP-EQUIV="Content-Type" Content="text/html; charset=us-ascii"></HEAD>
<BODY><h2>Bad Request - Invalid Hostname</h2>
<hr><p>HTTP Error 400. The request hostname is invalid.</p>
</BODY></HTML>
* Connection #0 to host 127.0.0.1 left intact

Respuesta1

Prueba con esta configuración:

events {
  worker_connections  1024; 
}

http { 
  upstream myapp {
    server 127.0.0.1:8001;
    server 127.0.0.1:8002;
    server 127.0.0.1:8003;
  }

  server {
    listen 8000;
    server_name 127.0.0.1;
    location / {
      proxy_pass http://myapp;
      proxy_set_header Host $host;
    }
  }
}

Respuesta2

Recibí el mismo error, perosoyusando nginx frente a IIS. Pero fue intermitente. Fueron todas las demás solicitudes las que fallaron, lo que fue extraño.

Resulta que había vinculado mi nombre de host de IIS a una IP específica (a diferencia de todas las IP) e IIS estaba equilibrando la carga pero no podía resolver la otra IP.

Decirle a IIS que se vincule a todas las IP lo resolvió. Sólo tomó un par de horas darse cuenta de eso.

información relacionada