Akka Routing: el envío de la respuesta al enrutador termina como letras muertas
Estoy jugando con Actor Routing y no puedo enviar una respuesta al enrutador para que otro actor en la lista de enrutamiento pueda escuchar esto, ¿qué no veo aquí?)
Estoy usando:
sender.tell([Message], context.parent)
Para responder al enrutador según los documentos de akka, los actores enrutados configuran el remitente a sí mismos y su padre es el enrutador real.
Al responder, aparecerá el siguiente mensaje en la consola:
[INFO] [13/12/2013 11: 19: 43.030] [StarBucks-akka.actor.default-dispatcher-2] [akka: // StarBucks / deadLetters] Mensaje [net.addictivesoftware.starbucks.MakeCoffee $] de Actor [akka: // StarBucks / user / Melanie # -847662818] para Actor [akka: // StarBucks / deadLetters] no fue entregado. [1] letras muertas encontradas.
La clase principal es:
object Starbucks extends App {
implicit val system = ActorSystem.create("StarBucks")
val employees = List(
system.actorOf(Props[Employee], "Penny"),
system.actorOf(Props[Employee], "Leonard"),
system.actorOf(Props[Employee], "Sheldon")
)
val customers = List(
("Raj", "Tall Latte Machiato"),
("Howard", "Double Tall Cappuccino"),
("Bernadette", "Grande Spicy Pumpkin Latte"),
("Amy", "Dopio Espresso")
)
val starBucks = system.actorOf(
Props.empty.withRouter(SmallestMailboxRouter(routees=employees)))
customers foreach { request =>
println("Customer %s orders a %s".format(request._1, request._2))
starBucks ! CanIHave(request._1, request._2)
}
}
La clase de actor enrutado es:
class Employee extends Actor {
def receive = {
case CanIHave(coffee, name) => {
println("Employee %s writes '%s' and '%s' on a cup".format(self.path.name, coffee, name) )
sender.tell(MakeCoffee(coffee, name), context.parent)
}
case MakeCoffee(coffee, name) => {
println("Employee %s makes a %s for %s ".format(self.path.name, coffee, name) )
sender.tell(CoffeeReady(coffee, name), context.parent)
}
case CoffeeReady(coffee, name) => {
println("Employee %s shouts: %s for %s is ready!".format(self.path, name, coffee, name))
}
}
}