Get existing or create new akka actor

后端 未结 3 1556
生来不讨喜
生来不讨喜 2020-12-31 17:33

I\'m trying to get an existing ActorRef with ActorFor or create a new one if it does not exists. I have the following code but it doesn\'t seem to work as expected. .isTermi

相关标签:
3条回答
  • 2020-12-31 18:03

    Get-or-create can only be performed by the parent of the designated actor, since only that parent can create the actor if it does not exist, and only the parent can do so consistently (i.e. without race conditions). Within an actor you can do

    // assuming a String name like "fred" or "barney", i.e. without "/"
    final Option<ActorRef> child = child(name);
    if (child.isDefined())
      return child.get();
    else
      return getContext().actorOf(..., name);
    

    Do not do this at the top-level (i.e. using system.actorOf), because then you cannot be sure who “wins” in requesting creation and also relying on the user guardian is not good a good supervision strategy.

    0 讨论(0)
  • 2020-12-31 18:19

    Based on the given code you are calling actorFor to look up a non-existent actor. The actor doesn't exist until actorOf is called.

    0 讨论(0)
  • 2020-12-31 18:26

    Change your lookup to be:

    system.actorFor("/user/" + name)
    

    You don't need the "akka://System" part if this is a local actor you are looking up. This is assuming that this actor was already started up elsewhere in your code though. If not it won't work.

    0 讨论(0)
提交回复
热议问题