从数据库初始化actor的最佳实践方法是什么?

时间:2012-12-03 14:43:51

标签: database scala initialization akka actor

我有一个顶级演员(在守护者下),名为Groups,在启动时需要从数据库加载组列表,并根据数据库中的这些组创建一组子actor。 / p>

我已将数据库加载代码放在preStart函数中,因为我不希望在加载组之前处理任何消息。

目前我的Groups演员看起来像这样;

var groups: Map[String, ActorRef] = Map()

override def preStart() = {
  groups = getGroupsFromDB() map createGroup
}

def createGroup(pair: (String, Long)) = {
  val (name, id) = pair
  val group = context.actorOf(Props(new Group(id, name)), name = name)

  name -> group
}

但是,我不相信这是处理此问题的最佳方法,因为如果数据库服务器不可用会发生什么?那么从数据库处理数据初始化的最佳实践方法是什么?

1 个答案:

答案 0 :(得分:1)

Akka documentation解释了如何监督顶级演员的容错能力。

如果数据库不可用,您可以在那里应用原则来管理您可能会发现的例外情况。