Upstream hash: reordered peer checks.
This slightly reduces cost of selecting a peer if all or almost all peers failed, see ticket #1030. There should be no measureable difference with other workloads.
This commit is contained in:
parent
a10ec2db91
commit
53d655f894
@ -543,13 +543,6 @@ ngx_http_upstream_get_chash_peer(ngx_peer_connection_t *pc, void *data)
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (peer->server.len != server->len
|
|
||||||
|| ngx_strncmp(peer->server.data, server->data, server->len)
|
|
||||||
!= 0)
|
|
||||||
{
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (peer->max_fails
|
if (peer->max_fails
|
||||||
&& peer->fails >= peer->max_fails
|
&& peer->fails >= peer->max_fails
|
||||||
&& now - peer->checked <= peer->fail_timeout)
|
&& now - peer->checked <= peer->fail_timeout)
|
||||||
@ -561,6 +554,13 @@ ngx_http_upstream_get_chash_peer(ngx_peer_connection_t *pc, void *data)
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (peer->server.len != server->len
|
||||||
|
|| ngx_strncmp(peer->server.data, server->data, server->len)
|
||||||
|
!= 0)
|
||||||
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
peer->current_weight += peer->effective_weight;
|
peer->current_weight += peer->effective_weight;
|
||||||
total += peer->effective_weight;
|
total += peer->effective_weight;
|
||||||
|
|
||||||
|
@ -544,13 +544,6 @@ ngx_stream_upstream_get_chash_peer(ngx_peer_connection_t *pc, void *data)
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (peer->server.len != server->len
|
|
||||||
|| ngx_strncmp(peer->server.data, server->data, server->len)
|
|
||||||
!= 0)
|
|
||||||
{
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (peer->max_fails
|
if (peer->max_fails
|
||||||
&& peer->fails >= peer->max_fails
|
&& peer->fails >= peer->max_fails
|
||||||
&& now - peer->checked <= peer->fail_timeout)
|
&& now - peer->checked <= peer->fail_timeout)
|
||||||
@ -562,6 +555,13 @@ ngx_stream_upstream_get_chash_peer(ngx_peer_connection_t *pc, void *data)
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (peer->server.len != server->len
|
||||||
|
|| ngx_strncmp(peer->server.data, server->data, server->len)
|
||||||
|
!= 0)
|
||||||
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
peer->current_weight += peer->effective_weight;
|
peer->current_weight += peer->effective_weight;
|
||||||
total += peer->effective_weight;
|
total += peer->effective_weight;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user