我有一个顶级演员(在守护者下),名为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
}
但是,我不相信这是处理此问题的最佳方法,因为如果数据库服务器不可用会发生什么?那么从数据库处理数据初始化的最佳实践方法是什么?