Welcome! Log In Create A New Profile

Advanced

[nginx] svn commit: r5113 - trunk/src/http

Anonymous User
March 14, 2013 08:38AM
Author: mdounin
Date: 2013-03-14 12:37:54 +0000 (Thu, 14 Mar 2013)
New Revision: 5113
URL: http://trac.nginx.org/nginx/changeset/5113/nginx

Log:
Upstream: call ngx_http_run_posted_requests() on resolve errors.

If proxy_pass to a host with dynamic resolution was used to handle
a subrequest, and host resolution failed, the main request wasn't run
till something else happened on the connection. E.g. request to "/zzz"
with the following configuration hanged:

addition_types *;
resolver 8.8.8.8;

location /test {
set $ihost xxx;
proxy_pass http://$ihost;
}

location /zzz {
add_after_body /test;
return 200 "test";
}

Report and original version of the patch by Lanshun Zhou,
http://mailman.nginx.org/pipermail/nginx-devel/2013-March/003476.html.


Modified:
trunk/src/http/ngx_http_upstream.c

Modified: trunk/src/http/ngx_http_upstream.c
===================================================================
--- trunk/src/http/ngx_http_upstream.c 2013-03-14 12:30:26 UTC (rev 5112)
+++ trunk/src/http/ngx_http_upstream.c 2013-03-14 12:37:54 UTC (rev 5113)
@@ -894,7 +894,7 @@
ngx_resolver_strerror(ctx->state));

ngx_http_upstream_finalize_request(r, u, NGX_HTTP_BAD_GATEWAY);
- return;
+ goto failed;
}

ur->naddrs = ctx->naddrs;
@@ -919,13 +919,17 @@
if (ngx_http_upstream_create_round_robin_peer(r, ur) != NGX_OK) {
ngx_http_upstream_finalize_request(r, u,
NGX_HTTP_INTERNAL_SERVER_ERROR);
- return;
+ goto failed;
}

ngx_resolve_name_done(ctx);
ur->ctx = NULL;

ngx_http_upstream_connect(r, u);
+
+failed:
+
+ ngx_http_run_posted_requests(r->connection);
}



_______________________________________________
nginx-devel mailing list
nginx-devel@nginx.org
http://mailman.nginx.org/mailman/listinfo/nginx-devel
Subject Author Views Posted

[nginx] svn commit: r5113 - trunk/src/http

Anonymous User 635 March 14, 2013 08:38AM



Sorry, you do not have permission to post/reply in this forum.

Online Users

Guests: 270
Record Number of Users: 8 on April 13, 2023
Record Number of Guests: 421 on December 02, 2018
Powered by nginx      Powered by FreeBSD      PHP Powered      Powered by MariaDB      ipv6 ready