ActorSystem单例注入

时间:2019-07-17 11:03:49

标签: scala dependency-injection singleton akka akka-actor

在我的项目中,我必须使用参与者和调度程序。我所有的需求只能通过使用一个actor系统来完成。但是我需要一个以上班级的调度员和演员。所以我的问题是,如果我应该像下面那样在每个类中注入actor系统,它将创建一个actor系统还是一个以上actor系统?我不希望创建多个参与者系统,因为这不是推荐的做法。

import akka.actor.ActorSystem

@Singleton
class someClass @Inject()(actorSystem: ActorSystem){....} // abstract class ActorSystem extends ActorRefFactory

@Singleton
class anotherClass @Inject()(actorSystem: ActorSystem){....}

或者我应该创建另一个对象,并在其中声明一个actor系统,并像这样在各处使用它:

import akka.actor._

object actorSystemObject {
    val system: ActorSystem = ActorSystem()
}

哪种方法更好,更标准?

1 个答案:

答案 0 :(得分:4)

假设您正在使用guice,请像这样尝试providingsingleton

@Provides
@Singleton
def getActorSystem: ActorSystem = ActorSystem()

例如

import akka.actor.ActorSystem
import com.google.inject.{AbstractModule, Guice, Inject, Injector, Provides, Singleton}
import scala.jdk.CollectionConverters._

class MyModule extends AbstractModule {
  @Provides
  @Singleton
  def getActorSystem: ActorSystem = ActorSystem()
}

@Singleton
class SomeClass @Inject()(actorSystem: ActorSystem) {
  println(actorSystem.hashCode())
}

@Singleton
class SomeOtherClass @Inject()(actorSystem: ActorSystem) {
  println(actorSystem.hashCode())
}

object Hello extends App {
  val injector: Injector = Guice.createInjector(List(new MyModule).asJava)
  injector.getInstance(classOf[SomeClass])
  injector.getInstance(classOf[SomeOtherClass])
}

输出类似

的内容
1731656333
1731656333

在我们看到相同的ActorSystem被注入的情况下,同样的hashCode也是如此。

说我们像这样删除@Singleton提供程序

@Provides
def getActorSystem: ActorSystem = ActorSystem()

然后hashCode个不同,例如,

2050462663
1117871068