Solución de problemas de errores 502 en ARR
Este artículo le ayuda a resolver los problemas relacionados con los errores 502 en el enrutamiento de solicitudes de aplicación (ARR).
Se aplica a: Internet Information Services
HTTP 502: Información general
Al trabajar con implementaciones de enrutamiento de solicitudes de aplicación de IIS (ARR), uno de los errores que podría ver es "HTTP 502 - Puerta de enlace incorrecta". El error 502.3 significa que, al actuar como proxy, ARR no pudo completar la solicitud al servidor ascendente y enviar una respuesta al cliente. Este problema puede ocurrir por varias razones. Por ejemplo, si no se conecta al servidor, no se responde desde el servidor o el servidor tarda demasiado tiempo en responder (tiempo de espera). Si puede reproducir el error examinando la granja de servidores web desde el controlador y los errores detallados están habilitados en el servidor, es posible que vea un error similar al siguiente mensaje de error:
La causa principal del error determina lo que debe hacer para resolver el problema.
Errores de tiempo de espera 502.3
ARR usa el código de error en la captura de pantalla anterior para proxy de la solicitud y determinar el origen del error porque contiene el código devuelto de WinHTTP.
Puede descodificar el código de error con la herramienta err.exe. En este ejemplo, el código de error se asigna a ERROR_WINHTTP_TIMEOUT. También puede encontrar esta información en los registros de IIS del sitio web asociado en el controlador de ARR. A continuación, se muestra un extracto de la entrada de registro de IIS para el error 502.3, con la mayoría de los campos recortados para mejorar la legibilidad:
sc-status | sc-substatus | sc-win32-status | time-taken |
---|---|---|---|
502 | 3 | 12002 | 29889 |
El estado win32 12002 se asigna al mismo error ERROR_WINHTTP_TIMEOUT notificado en la página de error.
¿Qué agotó su tiempo de espera?
Para comprobar este tiempo de espera, habilite el seguimiento de solicitudes con error en el servidor IIS. El primer punto al que puede ver, en el registro de seguimiento de solicitudes con error y aquí es donde se envió la solicitud en el evento ARR_SERVER_ROUTED. El segundo punto es el X-ARR-LOG-ID, que puede usar para realizar el seguimiento de la solicitud en el servidor de destino. Esto ayuda a realizar un seguimiento del destino o destino de la solicitud HTTP:
77. ARR_SERVER_ROUTED RoutingReason="LoadBalancing", Server="192.168.0.216", State="Active", TotalRequests="3", FailedRequests="2", CurrentRequests="1", BytesSent="648", BytesReceived="0", ResponseTime="15225" 16:50:21.033
78. GENERAL_SET_REQUEST_HEADER HeaderName="Max-Forwards", HeaderValue="10", Replace="true" 16:50:21.033
79. GENERAL_SET_REQUEST_HEADER HeaderName="X-Forwarded-For", HeaderValue="192.168.0.204:49247", Replace="true" 16:50:21.033
80. GENERAL_SET_REQUEST_HEADER HeaderName="X-ARR-SSL", HeaderValue="", Replace="true" 16:50:21.033
81. GENERAL_SET_REQUEST_HEADER HeaderName="X-ARR-ClientCert", HeaderValue="", Replace="true" 16:50:21.033
82. GENERAL_SET_REQUEST_HEADER HeaderName="X-ARR-LOG-ID", HeaderValue="dbf06c50-adb0-4141-8c04-20bc2f193a61", Replace="true" 16:50:21.033
83. GENERAL_SET_REQUEST_HEADER HeaderName="Connection", HeaderValue="", Replace="true" 16:50:21.033
En el ejemplo siguiente se muestra cómo podría verse esto en los registros de seguimiento de solicitudes con error del servidor de destino. Puede validar que ha encontrado la solicitud correcta haciendo coincidir los valores "X-ARR-LOG-ID" en ambos seguimientos.
185. GENERAL_REQUEST_HEADERS Headers="Connection: Keep-Alive Content-Length: 0 Accept: */* Accept-Encoding: gzip, deflate Accept-Language: en-US Host: test Max-Forwards: 10 User-Agent: Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 6.1; WOW64; Trident/4.0) X-Original-URL: /time/ X-Forwarded-For: 192.168.0.204:49247 X-ARR-LOG-ID: dbf06c50-adb0-4141-8c04-20bc2f193a61
<multiple entries skipped for brevity>
345. GENERAL_FLUSH_RESPONSE_END BytesSent="0", ErrorCode="An operation was attempted on a nonexistent network connection. (0x800704cd)" 16:51:06.240
En el ejemplo anterior, puede ver que el servidor ARR se desconecta antes de enviar la respuesta HTTP. La marca de tiempo de GENERAL_FLUSH_RESPONSE_END se puede usar como guía aproximada para encontrar la entrada correspondiente en los registros de IIS en el servidor de destino.
date | time | s-ip | cs-method | cs-uri-stem | cs-uri-query | s-port | cs-username | sc-status | sc-substatus | sc-win32-status | time-taken |
---|---|---|---|---|---|---|---|---|---|---|---|
2011-07-18 | 16:51:06 | 192.168.0.216 | GET | /Hora/ | - | 80 | - | 200 | 0 | 64 | 45208 |
IIS en el servidor de destino registró un código de estado HTTP 200, lo que indica que la solicitud se completó correctamente. Además, el estado win32 ha cambiado a 64, que se asigna a ERROR_NETNAME_DELETED. Este código de estado suele indicar que el cliente (ARR es el "cliente" en este caso) se desconecta antes de que se complete la solicitud.
Causa
El servidor ARR notificó un tiempo de espera, que es donde debe buscar primero.
Aunque el registro del servidor miembro indica que la respuesta se envió en 45 segundos (45208 ms), la entrada de registro de IIS del servidor ARR indica que el tiempo que se tarda es muy cercano a 30 segundos. Esto indica que ARR agota el tiempo de espera de la solicitud y puede confirmarlo examinando el tiempo de espera del proxy en la configuración del proxy de la granja de servidores. De forma predeterminada, se establece en 30 segundos.
Por lo tanto, en este caso, puede ver claramente que el tiempo de espera de ARR era más corto que la ejecución de la solicitud. Por lo tanto, es posible que desee comprobar si este tiempo de ejecución era típico o si necesitaba examinar por qué la solicitud tardaba más de lo esperado. Si se esperaba este tiempo de ejecución y era normal, aumentar el tiempo de espera de ARR debería resolver el error.
Otras posibles razones para ERROR_WINHTTP_TIMEOUT incluyen:
ResolveTimeout
: se produce si la resolución de nombres tarda más tiempo que el período de tiempo de espera especificado.ConnectTimeout
: se produce si tarda más tiempo que el período de tiempo de espera especificado para conectarse al servidor después de resolver el nombre.SendTimeout
: se produce si el envío de una solicitud tarda más de este valor de tiempo de espera. Se cancela la operación de envío.ReceiveTimeout
: se produce si una respuesta tarda más de este valor de tiempo de espera. La solicitud se cancela.
Al observar las dos primeras razones y ResolveTimeout
ConnectTimeout
, la metodología de solución de problemas descrita anteriormente no funcionaría. Esto se debe a que no vería ningún tráfico en el servidor de destino y, por tanto, no conocería el código de error. Por lo tanto, en este caso de ResolveTimeout
o ConnectTimeout
es posible que quiera capturar un seguimiento winHTTP para obtener información adicional. Consulte la sección Seguimiento de WinHTTP o WEBIO y en los blogs siguientes para ver otros ejemplos sobre la solución de problemas y el seguimiento:
- 502.3 Puerta de enlace incorrecta "La operación agotó el tiempo de espera" con el enrutamiento de solicitudes de aplicación de IIS (ARR)
- Opciones de seguimiento de Winhttp para solucionar problemas con el enrutamiento de solicitudes de aplicación
502.3 Errores de terminación de conexión
También se devuelven errores 502.3 cuando la conexión entre ARR y el servidor miembro se desconecta a mitad del flujo. Para probar este tipo de problema, cree una página de .aspx que llame a Response.Close()
. En el ejemplo siguiente, hay un directorio denominado "time", que se configura con una página de .aspx como documento predeterminado en ese directorio. Al intentar examinar el directorio, ARR muestra el siguiente mensaje de error:
El 0x80072efe de error corresponde a ERROR_INTERNET_CONNECTION_ABORTED. La solicitud se puede realizar un seguimiento al servidor que realmente la procesó mediante los mismos pasos que se usaron anteriormente en este solucionador de problemas, con una excepción. Aunque el seguimiento de solicitudes con error en el servidor de destino muestra la solicitud procesada en el servidor, la entrada de registro asociada no aparece en los registros de IIS. En su lugar, esta solicitud se registra en el registro HTTPERR de la siguiente manera:
HTTP/1.1 GET /time/ - 1 Connection_Dropped DefaultAppPool
Los registros integrados en el servidor de destino no proporcionan información adicional sobre el problema, por lo que el siguiente paso sería recopilar un seguimiento de red del servidor ARR. En el ejemplo anterior, la página .aspx llamada Response.Close()
sin devolver ningún dato. Ver esto en un seguimiento de red mostraría que un Connection: close
encabezado HTTP provenía del servidor de destino. Con esta información, podría iniciar una investigación sobre por qué se envió el Connection: close
encabezado.
El siguiente error es otro ejemplo de una respuesta no válida del servidor miembro:
En este ejemplo, ARR comenzó a recibir datos del cliente, pero algo salió mal al leer el cuerpo de la entidad de solicitud. Esto dio lugar a que se devolva el código de error 0x80072f78. Para investigar más, use Network Monitor en el servidor miembro para obtener un seguimiento de red del problema. Este ejemplo de error concreto se creó llamando Response.Close()
a en la página de ASP.net después de enviar parte de la respuesta y, a continuación, llamando a Response.Flush()
. Si el tráfico entre el servidor ARR y los servidores miembros se realiza a través de SSL, el seguimiento de WinHTTP en el seguimiento de Windows Server 2008 o WebIO en Windows Server 2008 R2 puede proporcionar información adicional. El seguimiento de WebIO se describe más adelante en este solucionador de problemas.
502.4 No se encontró ningún servidor adecuado para enrutar la solicitud
El error HTTP 502.4 con un código de error asociado de 0x00000000 suele indicar que todos los miembros de la granja están sin conexión o no son accesibles.
El primer paso es comprobar que los servidores miembros están en línea. Para comprobarlo, vaya al nodo Servidores de la granja en el Administrador de IIS.
Para devolver los servidores sin conexión, haga clic con el botón derecho en el nombre del servidor y seleccione Agregar al equilibrio de carga. Si no puede volver a conectar los servidores, compruebe si los servidores miembros son accesibles desde el servidor ARR. Compruebe el panel Mensajes de seguimiento en la página Servidores para buscar algunas pistas sobre el problema. Si usa Web Farm Framework (WFF) 2.0, puede recibir este error cuando se reinicie el grupo de aplicaciones. Debe reiniciar el servicio de granja de servidores web para recuperarse.
Seguimiento de WinHTTP o WebIO
Normalmente, las herramientas de captura de paquetes como WireShark proporcionan la información necesaria para identificar exactamente lo que se agota el tiempo de espera. Sin embargo, hay ocasiones (por ejemplo, cuando el tráfico está cifrado SSL) que tendrá que probar un enfoque diferente. A partir de Windows 7 y Windows Server 2008 R2, puede habilitar el seguimiento de WinHTTP mediante la herramienta netsh ejecutando el siguiente comando desde un símbolo del sistema administrativo:
netsh trace start scenario=internetclient capture=yes persistent=no level=verbose tracefile=c:\temp\net.etl
Después de esto, reproduzca el problema. Una vez reproducido el problema, detenga el seguimiento ejecutando el siguiente comando:
netsh trace stop
El stop
comando tarda unos segundos en finalizar. Cuando haya terminado, encontrará un archivo net.etl y un archivo net.cab en C:\temp
. Deberá asegurarse de que la C:\temp
carpeta existe antes de ejecutar los comandos anteriores. El archivo .cab contiene registros de eventos y otros datos que pueden resultar útiles para analizar el archivo .etl.
Para analizar el registro,
Ábralo en Netmon 3.4 o posterior.
Asegúrese de que ha configurado el perfil del analizador. Para ello, abra el menú Opciones de herramientas>, seleccione la pestaña >Perfiles del analizador Perfil de Windows y, a continuación, seleccione el botón Establecer como activo para aplicar los cambios.
Desplácese por el seguimiento hasta que encuentre la instancia de w3wp.exe donde se ejecuta ARR mediante la correlación con la columna nombre del proceso ut.
Haga clic con el botón derecho en w3wp y seleccione Agregar nombre de proceso ut para mostrar el filtro. Esto establece el filtro de presentación similar al siguiente:
UTProcessName == "w3wp.exe (1432)"
Modifique esto para poder filtrar aún más los resultados:
UTProcessName == "w3wp.exe (<pid>)" AND ProtocolName == "WINHTTP_MicrosoftWindowsWinHttp"
Tendrá que desplazarse por la salida hasta que encuentre el error de tiempo de espera. En el ejemplo siguiente, se agota el tiempo de espera de una solicitud porque tardó más de 30 segundos (tiempo de espera predeterminado de ARR) en ejecutarse.
336 2:32:22 PM 7/22/2011 32.6380453 w3wp.exe (1432) WINHTTP_MicrosoftWindowsWinHttp WINHTTP_MicrosoftWindowsWinHttp:12:32:23.123 ::sys-recver starts in _INIT state
337 2:32:22 PM 7/22/2011 32.6380489 w3wp.exe (1432) WINHTTP_MicrosoftWindowsWinHttp WINHTTP_MicrosoftWindowsWinHttp:12:32:23.123 ::current thread is not impersonating
340 2:32:22 PM 7/22/2011 32.6380584 w3wp.exe (1432) WINHTTP_MicrosoftWindowsWinHttp WINHTTP_MicrosoftWindowsWinHttp:12:32:23.123 ::sys-recver processing WebReceiveHttpResponse completion (error-cdoe = ? (0x5b4), overlapped = 003728F0)
341 2:32:22 PM 7/22/2011 32.6380606 w3wp.exe (1432) WINHTTP_MicrosoftWindowsWinHttp WINHTTP_MicrosoftWindowsWinHttp:12:32:23.123 ::sys-recver failed to receive headers; error = ? (1460)
342 2:32:22 PM 7/22/2011 32.6380800 w3wp.exe (1432) WINHTTP_MicrosoftWindowsWinHttp WINHTTP_MicrosoftWindowsWinHttp:12:32:23.123 ::ERROR_WINHTTP_FROM_WIN32 mapped (?) 1460 to (ERROR_WINHTTP_TIMEOUT) 12002
343 2:32:22 PM 7/22/2011 32.6380829 w3wp.exe (1432) WINHTTP_MicrosoftWindowsWinHttp WINHTTP_MicrosoftWindowsWinHttp:12:32:23.123 ::sys-recver returning ERROR_WINHTTP_TIMEOUT (12002) from RecvResponse()
344 2:32:22 PM 7/22/2011 32.6380862 w3wp.exe (1432) WINHTTP_MicrosoftWindowsWinHttp WINHTTP_MicrosoftWindowsWinHttp:12:32:23.123 ::sys-req completes recv-headers inline (sync); error = ERROR_WINHTTP_TIMEOUT (12002)
En el ejemplo siguiente, el servidor de contenido estaba completamente sin conexión:
42 2:26:39 PM 7/22/2011 18.9279133 WINHTTP_MicrosoftWindowsWinHttp WINHTTP_MicrosoftWindowsWinHttp:12:26:39.704 ::WinHttpReceiveResponse(0x11d23d0, 0x0) {WINHTTP_MicrosoftWindowsWinHttp:4, NetEvent:3}
43 2:26:39 PM 7/22/2011 18.9279633 WINHTTP_MicrosoftWindowsWinHttp WINHTTP_MicrosoftWindowsWinHttp:12:26:39.704 ::sys-recver starts in _INIT state {WINHTTP_MicrosoftWindowsWinHttp:4, NetEvent:3}
44 2:26:39 PM 7/22/2011 18.9280469 WINHTTP_MicrosoftWindowsWinHttp WINHTTP_MicrosoftWindowsWinHttp:12:26:39.704 ::current thread is not impersonating {WINHTTP_MicrosoftWindowsWinHttp:4, NetEvent:3}
45 2:26:39 PM 7/22/2011 18.9280776 WINHTTP_MicrosoftWindowsWinHttp WINHTTP_MicrosoftWindowsWinHttp:12:26:39.704 ::sys-recver processing WebReceiveHttpResponse completion (error-cdoe = WSAETIMEDOUT (0x274c), overlapped = 003728F0) {WINHTTP_MicrosoftWindowsWinHttp:4, NetEvent:3}
46 2:26:39 PM 7/22/2011 18.9280802 WINHTTP_MicrosoftWindowsWinHttp WINHTTP_MicrosoftWindowsWinHttp:12:26:39.704 ::sys-recver failed to receive headers; error = WSAETIMEDOUT (10060) {WINHTTP_MicrosoftWindowsWinHttp:4, NetEvent:3}
47 2:26:39 PM 7/22/2011 18.9280926 WINHTTP_MicrosoftWindowsWinHttp WINHTTP_MicrosoftWindowsWinHttp:12:26:39.704 ::ERROR_WINHTTP_FROM_WIN32 mapped (WSAETIMEDOUT) 10060 to (ERROR_WINHTTP_TIMEOUT) 12002 {WINHTTP_MicrosoftWindowsWinHttp:4, NetEvent:3}
48 2:26:39 PM 7/22/2011 18.9280955 WINHTTP_MicrosoftWindowsWinHttp WINHTTP_MicrosoftWindowsWinHttp:12:26:39.704 ::sys-recver returning ERROR_WINHTTP_TIMEOUT (12002) from RecvResponse() {WINHTTP_MicrosoftWindowsWinHttp:4, NetEvent:3}
Otros recursos
- Herramienta de búsqueda de errores
- Códigos de error de WinHttp
- Seguimiento de solicitudes erróneas.
- Seguimiento de Winhttp
- Monitor de red
Aviso de declinación de responsabilidades sobre la información de terceros
Los productos de otros fabricantes que se mencionan en este artículo han sido creados por compañías independientes de Microsoft. Microsoft no ofrece ninguna garantía, ya sea implícita o de otro tipo, sobre la confiabilidad o el rendimiento de dichos productos.