c

akka.routing

Router

final case class Router(logic: RoutingLogic, routees: IndexedSeq[Routee] = Vector.empty) extends Product with Serializable

For each message that is sent through the router via the #route method the RoutingLogic decides to which Routee to send the message. The Routee itself knows how to perform the actual sending. Normally the RoutingLogic picks one of the contained routees, but that is up to the implementation of the RoutingLogic.

A Router is immutable and the RoutingLogic must be thread safe.

Source
Router.scala
Type Hierarchy
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. Router
  2. Serializable
  3. Serializable
  4. Product
  5. Equals
  6. AnyRef
  7. Any
Implicitly
  1. by any2stringadd
  2. by StringFormat
  3. by Ensuring
  4. by ArrowAssoc
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Instance Constructors

  1. new Router(logic: RoutingLogic, routees: Iterable[Routee])

    Java API

  2. new Router(logic: RoutingLogic)

    Java API

  3. new Router(logic: RoutingLogic, routees: IndexedSeq[Routee] = Vector.empty)

Value Members

  1. def addRoutee(sel: ActorSelection): Router

    Create a new instance with one more ActorSelectionRoutee for the specified akka.actor.ActorSelection and the same RoutingLogic.

  2. def addRoutee(ref: ActorRef): Router

    Create a new instance with one more ActorRefRoutee for the specified akka.actor.ActorRef and the same RoutingLogic.

  3. def addRoutee(routee: Routee): Router

    Create a new instance with one more routee and the same RoutingLogic.

  4. val logic: RoutingLogic
  5. def removeRoutee(sel: ActorSelection): Router

    Create a new instance without the ActorSelectionRoutee for the specified akka.actor.ActorSelection.

  6. def removeRoutee(ref: ActorRef): Router

    Create a new instance without the ActorRefRoutee for the specified akka.actor.ActorRef.

  7. def removeRoutee(routee: Routee): Router

    Create a new instance without the specified routee.

  8. def route(message: Any, sender: ActorRef): Unit

    Send the message to the destination Routee selected by the RoutingLogic.

    Send the message to the destination Routee selected by the RoutingLogic. If the message is a akka.routing.RouterEnvelope it will be unwrapped before sent to the destinations. Messages wrapped in a Broadcast envelope are always sent to all routees.

  9. val routees: IndexedSeq[Routee]
  10. def withRoutees(rs: IndexedSeq[Routee]): Router

    Create a new instance with the specified routees and the same RoutingLogic.