# HG changeset patch # User Igor Sysoev # Date 1051108482 0 # Node ID 939bc7cd9a90b385b33e1091710361c3e804e29f # Parent eacfdd1c31b96793f7d17de772f84c3d88bda674 nginx-0.0.1-2003-04-23-18:34:42 import diff --git a/src/http/modules/proxy/ngx_http_event_proxy_handler.c b/src/http/modules/proxy/ngx_http_event_proxy_handler.c --- a/src/http/modules/proxy/ngx_http_event_proxy_handler.c +++ b/src/http/modules/proxy/ngx_http_event_proxy_handler.c @@ -371,8 +371,7 @@ static int ngx_http_proxy_process_upstre return NGX_DONE; } - if (p->tries /* STUB !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! */ - + if (p->tries > 1 && (rc == NGX_HTTP_BAD_GATEWAY || rc == NGX_HTTP_GATEWAY_TIME_OUT || (rc == NGX_OK @@ -1083,7 +1082,12 @@ static int ngx_http_proxy_read_upstream_ int rc; rc = ngx_event_proxy_read_upstream(p->event_proxy); - if (rc == NGX_OK) { + + if (p->event_proxy->fatal_error) { + return NGX_HTTP_INTERNAL_SERVER_ERROR; + } + + if (p->event_proxy->upstream_eof && p->event_proxy->upstream_error) { rc = ngx_event_close_connection(p->connection->read); }