[nginx] Upstream: detect port absence in fastcgi_pass with IP li...

Ruslan Ermilov ru at nginx.com
Wed Feb 11 12:51:42 UTC 2015


details:   http://hg.nginx.org/nginx/rev/26c127bab5ef
branches:  
changeset: 5977:26c127bab5ef
user:      Ruslan Ermilov <ru at nginx.com>
date:      Thu Jan 22 16:23:32 2015 +0300
description:
Upstream: detect port absence in fastcgi_pass with IP literal.

If fastcgi_pass (or any look-alike that doesn't imply a default
port) is specified as an IP literal (as opposed to a hostname),
port absence was not detected at configuration time and could
result in EADDRNOTAVAIL at run time.

Fixed this in such a way that configs like

http {
    server {
        location / {
            fastcgi_pass 127.0.0.1;
        }
    }

    upstream 127.0.0.1 {
        server 10.0.0.1:12345;
    }
}

still work.  That is, port absence check is delayed until after
we make sure there's no explicit upstream with such a name.

diffstat:

 src/http/ngx_http_upstream.c |  2 +-
 1 files changed, 1 insertions(+), 1 deletions(-)

diffs (12 lines):

diff -r 814583aef808 -r 26c127bab5ef src/http/ngx_http_upstream.c
--- a/src/http/ngx_http_upstream.c	Wed Feb 11 15:51:03 2015 +0300
+++ b/src/http/ngx_http_upstream.c	Thu Jan 22 16:23:32 2015 +0300
@@ -5408,7 +5408,7 @@ ngx_http_upstream_add(ngx_conf_t *cf, ng
     uscf->default_port = u->default_port;
     uscf->no_port = u->no_port;
 
-    if (u->naddrs == 1) {
+    if (u->naddrs == 1 && (u->port || u->family == AF_UNIX)) {
         uscf->servers = ngx_array_create(cf->pool, 1,
                                          sizeof(ngx_http_upstream_server_t));
         if (uscf->servers == NULL) {



More information about the nginx-devel mailing list