[zeromq-dev] RPC design pattern
Martin Sustrik
sustrik at 250bpm.com
Mon Apr 19 12:19:53 CEST 2010
Brian Candler wrote:
> On Mon, Apr 19, 2010 at 11:01:24AM +0200, Martin Sustrik wrote:
>> Yes. This can be achieved in two ways:
>>
>> 1. On top of 0MQ. Each client simply chooses a random server to connect to.
>
> But I didn't think the 0MQ API provided a way for the application to detect
> whether its chosen endpoint is reachable or not, and hence move to a
> different server. Or have I missed something?
No. There would be no failover in this case. The server would have to
come back online to process the request.
>> 2. Using a shared queue. All clients connect to the queue. All
>> servers connect to the queue. Queue manages fair load-balancing of
>> client requests among the servers.
>
> Sure - or a TCP load-balancer, if your server nodes are located near to each
> other.
>
> Having clients be able to failover to a secondary data centre, or load
> balance across two data centres, is still desirable.
Note that 0MQ is designed in such a way as to allow for N-hop message
routes. In this particular context it can mean, for instance, that
client can load-balance (and failover) between two datacenters, while
the queue within each datacenter can load-balance (and failover) between
service instances in the datacenter.
Martin
More information about the zeromq-dev
mailing list