Class ClusterSingletonProxy
- java.lang.Object
- 
- akka.cluster.singleton.ClusterSingletonProxy
 
- 
- All Implemented Interfaces:
- Actor,- ActorLogging
 
 public final class ClusterSingletonProxy extends java.lang.Object implements Actor, ActorLogging TheClusterSingletonProxyworks together with theClusterSingletonManagerto provide a distributed proxy to the singleton actor.The proxy can be started on every node where the singleton needs to be reached and used as if it were the singleton itself. It will then act as a router to the currently running singleton instance. If the singleton is not currently available, e.g., during hand off or startup, the proxy will buffer the messages sent to the singleton and then deliver them when the singleton is finally available. The size of the buffer is configurable and it can be disabled by using a buffer size of 0. When the buffer is full old messages will be dropped when new messages are sent via the proxy. The proxy works by keeping track of the oldest cluster member. When a new oldest member is identified, e.g. because the older one left the cluster, or at startup, the proxy will try to identify the singleton on the oldest member by periodically sending an Identifymessage until the singleton responds with itsActorIdentity.Note that this is a best effort implementation: messages can always be lost due to the distributed nature of the actors involved. 
- 
- 
Nested Class Summary- 
Nested classes/interfaces inherited from interface akka.actor.ActorActor.emptyBehavior$, Actor.ignoringBehavior$
 
- 
 - 
Constructor SummaryConstructors Constructor Description ClusterSingletonProxy(java.lang.String singletonManagerPath, ClusterSingletonProxySettings settings)
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description voidadd(Member m)Adds new member if it has the right role.scala.math.Ordering<Member>ageOrdering()protected voidakka$actor$Actor$_setter_$context_$eq(ActorContext x$1)Scala API: Stores the context for this actor, including self, and sender.protected voidakka$actor$Actor$_setter_$self_$eq(ActorRef x$1)The 'self' field holds the ActorRef for this actor.MessageBufferbuffer()voidbuffer(java.lang.Object msg)voidbuffer_$eq(MessageBuffer x$1)voidcancelTimer()Clustercluster()ActorContextcontext()Scala API: Stores the context for this actor, including self, and sender.java.lang.StringcreateIdentifyId(int i)voidhandleInitial(ClusterEvent.CurrentClusterState state)intidentifyCounter()voididentifyCounter_$eq(int x$1)java.lang.StringidentifyId()voididentifyId_$eq(java.lang.String x$1)voididentifySingleton()Discard old singleton ActorRef and send a periodic message to self to identify the singleton.scala.Option<Cancellable>identifyTimer()voididentifyTimer_$eq(scala.Option<Cancellable> x$1)booleanmatchingRole(Member member)scala.collection.immutable.SortedSet<Member>membersByAge()voidmembersByAge_$eq(scala.collection.immutable.SortedSet<Member> x$1)voidpostStop()User overridable callback.voidpreStart()User overridable callback.static Propsprops(java.lang.String singletonManagerPath, ClusterSingletonProxySettings settings)Scala API: Factory method forClusterSingletonProxyProps.scala.PartialFunction<java.lang.Object,scala.runtime.BoxedUnit>receive()Scala API: This defines the initial actor behavior, it must return a partial function with the actor logic.voidremove(Member m)Removes a member.ActorRefself()The 'self' field holds the ActorRef for this actor.voidsendBuffered()scala.Option<ActorRef>singleton()voidsingleton_$eq(scala.Option<ActorRef> x$1)java.lang.String[]singletonPath()voidtrackChange(scala.Function0<scala.runtime.BoxedUnit> block)- 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface akka.actor.ActoraroundPostRestart, aroundPostStop, aroundPreRestart, aroundPreStart, aroundReceive, postRestart, preRestart, sender, supervisorStrategy, unhandled
 - 
Methods inherited from interface akka.actor.ActorLogging_log_$eq, log
 
- 
 
- 
- 
- 
Constructor Detail- 
ClusterSingletonProxypublic ClusterSingletonProxy(java.lang.String singletonManagerPath, ClusterSingletonProxySettings settings)
 
- 
 - 
Method Detail- 
propspublic static Props props(java.lang.String singletonManagerPath, ClusterSingletonProxySettings settings) Scala API: Factory method forClusterSingletonProxyProps.- Parameters:
- singletonManagerPath- The logical path of the singleton manager, e.g.- /user/singletonManager, which ends with the name you defined in- actorOfwhen creating the- ClusterSingletonManager.
- settings- see- ClusterSingletonProxySettings
 
 - 
contextpublic ActorContext context() Description copied from interface:ActorScala API: Stores the context for this actor, including self, and sender. It is implicit to support operations such asforward.WARNING: Only valid within the Actor itself, so do not close over it and publish it to other threads! ActorContextis the Scala API.getContextreturns aAbstractActor.ActorContext, which is the Java API of the actor context.
 - 
selfpublic final ActorRef self() Description copied from interface:ActorThe 'self' field holds the ActorRef for this actor. Can be used to send messages to itself:self ! message 
 - 
akka$actor$Actor$_setter_$context_$eqprotected void akka$actor$Actor$_setter_$context_$eq(ActorContext x$1) Description copied from interface:ActorScala API: Stores the context for this actor, including self, and sender. It is implicit to support operations such asforward.WARNING: Only valid within the Actor itself, so do not close over it and publish it to other threads! ActorContextis the Scala API.getContextreturns aAbstractActor.ActorContext, which is the Java API of the actor context.- Specified by:
- akka$actor$Actor$_setter_$context_$eqin interface- Actor
 
 - 
akka$actor$Actor$_setter_$self_$eqprotected final void akka$actor$Actor$_setter_$self_$eq(ActorRef x$1) Description copied from interface:ActorThe 'self' field holds the ActorRef for this actor. Can be used to send messages to itself:self ! message - Specified by:
- akka$actor$Actor$_setter_$self_$eqin interface- Actor
 
 - 
singletonPathpublic java.lang.String[] singletonPath() 
 - 
identifyCounterpublic int identifyCounter() 
 - 
identifyCounter_$eqpublic void identifyCounter_$eq(int x$1) 
 - 
identifyIdpublic java.lang.String identifyId() 
 - 
identifyId_$eqpublic void identifyId_$eq(java.lang.String x$1) 
 - 
createIdentifyIdpublic java.lang.String createIdentifyId(int i) 
 - 
identifyTimerpublic scala.Option<Cancellable> identifyTimer() 
 - 
identifyTimer_$eqpublic void identifyTimer_$eq(scala.Option<Cancellable> x$1) 
 - 
clusterpublic Cluster cluster() 
 - 
singletonpublic scala.Option<ActorRef> singleton() 
 - 
singleton_$eqpublic void singleton_$eq(scala.Option<ActorRef> x$1) 
 - 
ageOrderingpublic scala.math.Ordering<Member> ageOrdering() 
 - 
membersByAgepublic scala.collection.immutable.SortedSet<Member> membersByAge() 
 - 
membersByAge_$eqpublic void membersByAge_$eq(scala.collection.immutable.SortedSet<Member> x$1) 
 - 
bufferpublic MessageBuffer buffer() 
 - 
buffer_$eqpublic void buffer_$eq(MessageBuffer x$1) 
 - 
preStartpublic void preStart() Description copied from interface:ActorUser overridable callback. Is called when an Actor is started. Actors are automatically started asynchronously when created. Empty default implementation.
 - 
postStoppublic void postStop() Description copied from interface:ActorUser overridable callback. Is called asynchronously after 'actor.stop()' is invoked. Empty default implementation.
 - 
cancelTimerpublic void cancelTimer() 
 - 
matchingRolepublic boolean matchingRole(Member member) 
 - 
handleInitialpublic void handleInitial(ClusterEvent.CurrentClusterState state) 
 - 
identifySingletonpublic void identifySingleton() Discard old singleton ActorRef and send a periodic message to self to identify the singleton.
 - 
trackChangepublic void trackChange(scala.Function0<scala.runtime.BoxedUnit> block) 
 - 
addpublic void add(Member m) Adds new member if it has the right role.- Parameters:
- m- New cluster member.
 
 - 
removepublic void remove(Member m) Removes a member.- Parameters:
- m- Cluster member to remove.
 
 - 
receivepublic scala.PartialFunction<java.lang.Object,scala.runtime.BoxedUnit> receive() Description copied from interface:ActorScala API: This defines the initial actor behavior, it must return a partial function with the actor logic.
 - 
bufferpublic void buffer(java.lang.Object msg) 
 - 
sendBufferedpublic void sendBuffered() 
 
- 
 
-