[edit] ip_hash

Syntax: ip_hash
Default:
Context: upstream
Reference: ip_hash


This directive causes requests to be distributed between upstreams based on the IP-address of the client.
The key for the hash is the class-C network address or the entire IPv6-address of the client. IPv6 is supported for ip_hash since 1.3.2 or 1.2.2. This method guarantees that the client request will always be transferred to the same server. But if this server is considered inoperative, then the request of this client will be transferred to another server. This gives a high probability clients will always connect to the same server.

It is not possible to combine ip_hash and weight methods for connection distribution until nginx 1.3.1 or 1.2.2. If one of the servers must be removed for some time, you must mark that server as *down*.

For example:

upstream backend {
  ip_hash;
  server   backend1.example.com weight=2;
  server   backend2.example.com;
  server   backend3.example.com  down;
  server   backend4.example.com;
}

Module: HttpUpstreamModule