exp*_*ert 7 scala actor akka akka-http akka-typed
如何混合有型和无类型的演员?我了解我的,当我创建实例指定主要演员ActorSystem像这样
val system: akka.typed.ActorSystem[Start] = akka.typed.ActorSystem("main", Props(mainBehaviour))
Run Code Online (Sandbox Code Playgroud)
另一方面,我使用像这样初始化的akka-http
implicit val system = ActorSystem()
implicit val executor = system.dispatcher
implicit val materializer = ActorMaterializer()
// etc...
Run Code Online (Sandbox Code Playgroud)
我看到我可以通过调用从无类型系统创建类型化系统
object ActorSystem {
def apply(untyped: akka.actor.ActorSystem): ActorSystem[Nothing] = new Wrapper(untyped.asInstanceOf[ExtendedActorSystem])
}
Run Code Online (Sandbox Code Playgroud)
所以假设我做到了
val typeSystem = akka.typed.ActorSystem(untypedSystem)
Run Code Online (Sandbox Code Playgroud)
如何创建我的第一个键入的演员typeSystem?有没有类型化的ActorContext,其actorOf我可以打电话.
我读过的关于这个主题的其他材料是
很好,这目前不太方便:您需要做的是创建类型化的 ActorSystem,然后访问底层的非类型化的 ActorSystem 以便启动 HTTP 扩展,但方法underlying是private[akka]. 您可以通过在 Akka 命名空间内的项目中放置一些帮助程序代码来访问它,或者您也可以采取相反的方式:
implicit val untyped = akka.actor.ActorSystem("main")
import untyped.dispatcher
implicit val mat = ActorMaterializer()
import akka.typed.Ops._
val typedRef = untyped.spawn(Props(mainBehaviour))
val typedSys = ActorSystem(untyped)
Http().bind(...) // and send things to typed
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
301 次 |
| 最近记录: |