Handling redirects among upstream servers

Maxim Dounin mdounin at mdounin.ru
Fri Nov 7 14:01:53 UTC 2014


Hello!

On Fri, Nov 07, 2014 at 05:11:44AM -0500, zappa wrote:

> Hello,
> 
> I'm trying to configure Nginx to access a cluster of application servers
> using a simple proxy with multiple application servers in the upstream. The
> application servers use a REST api for object storage and retrieval, and use
> 301 redirects among the nodes of the cluster for load balancing. A client
> can connect to server A, then get a redirect to server B, where the request
> will be handled.
> 
> This fails when nginx is used as a proxy in this case:
> 
> - the client connects through the proxy and gets connected to server A
> 
> - A returns a 301 with one of the other servers in the Location header
> 
> - Nginx rewrites the location header, so information about which node the
> client is supposed to connect to is lost
> 
> Does Nginx offer a solution for this? Can nginx handle the 301 itself
> without the client ever knowing the redirect happend? Would it be possible
> to store the redirect into a client cookie which is read during the next
> request and forces nginx to connect to a particular upstream server?

In no particular order:

- You can avoid changes to the Location header, or control them as 
  needed.  The flexibility provied by the proxy_redirect directive 
  should be enough to preserve information needed.  See 
  http://nginx.org/r/proxy_redirect for details.

- You can instruct nginx to forward requests to another node 
  by itself, using the X-Accel-Redirect header.  This may be a 
  good solution if you are willing to rewrite application servers to 
  use features provided by nginx.

- Redirections can be intercepted using the error_page and 
  proxy_intercept_errors directives (I wouldn't recommend this 
  though).

-- 
Maxim Dounin
http://nginx.org/



More information about the nginx mailing list