You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
{{ message }}
This repository has been archived by the owner on Aug 19, 2018. It is now read-only.
Scalecube currently gives answer for the current pattern of communication between services
request response
request many
request channel.
after giving it some thought i think scalecube does not answer pubsub communication pattern.
such as fanout, multicast, unicast and topic notion communication patterns between services.
having said that maybe we should consider Publisher / Consumer architecture for cases where we cant to broadcast messages to subscribers:
example scenario might be when we wish to broadcast stock symbols to multiple subscribers ect.
Although it can be done with Rsocket, i think Rsocket offered communication patterns mention above are less intuitive in such cases. as opposed for example to Aeron Consumer / Publishers. in addition current architecture of these communication patterns fits well when you deal with streams, but fits less well when you have to manage multiple subscribers in the cluster and emit one by one to each subscriber in order to create the effect of fanout for example as this will force you to write some boilerplate to manage retry and failures cases.
on the other hand Aeron publisher subscriber offer the notion of broadcasting which comes more intuitive when using UDP transport in these cases the need to manage logical streams on-top of single connections seems less needed thus the value of RSocket is questionable.
Maybe we should consider to offer PubSub layer on-top of Aeron transport with correlation to scalecube cluster to manage coordination of nodes in the cluster with microservices distributed architecture.
in such case we can offer Another transport and client similar to what we currently have with ServiceCall and RSocket patterns.
in case of PubSub patterns we can provide alternative channels for broadcasting messages and managing discovery and failures in the cluster on top of low latency high volume transport such as Aeron.
ronenhamias
changed the title
Manage subscriptions in a distributed cluster
PubSub Communication patterns.
Aug 5, 2018
Sign up for freeto subscribe to this conversation on GitHub.
Already have an account?
Sign in.
Motivation:
lets imagine we have 2 services in our cluster each service might go online and offline at any given point of time.
Service A depends on service B so we want to subscribe to this service when it appears in the cluster and wait for it to stream data to service B
currently this can be done using discovery events from service registry and service discovery.
to reduce the user boiler-plate we can offer an handler to service interface that will delegate events regards service dependencies in the cluster:
Proposed Solution
provide more way for user to react on discovery events by declaring handlers on service interface with regards to the service they want to "trap".
Alternative approach:
The text was updated successfully, but these errors were encountered: