本文整理汇总了Scala中akka.routing.ActorRefRoutee类的典型用法代码示例。如果您正苦于以下问题:Scala ActorRefRoutee类的具体用法?Scala ActorRefRoutee怎么用?Scala ActorRefRoutee使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了ActorRefRoutee类的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于我们的系统推荐出更棒的Scala代码示例。
示例1: XMPPChannelSupervisor
//设置package包名称以及导入依赖的类
package com.flipkart.connekt.busybees.clients
import akka.actor.{Actor, Props, Terminated}
import akka.routing.{ActorRefRoutee, RoundRobinRoutingLogic, Router}
import com.flipkart.connekt.commons.iomodels.XmppRequest
class XMPPChannelSupervisor(maxConnections: Int) extends Actor {
var router = {
val xmppChannelHandlers = Vector.fill(maxConnections) {
val r = context.actorOf(Props[XMPPChannelHandler])
context watch r
ActorRefRoutee(r)
}
Router(RoundRobinRoutingLogic(), xmppChannelHandlers)
}
override def receive: Receive = {
case d: XmppRequest =>
router.route(d, self)
case CreateNewXMPPChannelHandler =>
val r = context.actorOf(Props[XMPPChannelHandler])
r ! Configure
context watch r
router = router.addRoutee(r)
case Terminated(a) =>
router = router.removeRoutee(a)
val r = context.actorOf(Props[XMPPChannelHandler])
r ! Configure
context watch r
router = router.addRoutee(r)
}
}
case object CreateNewXMPPChannelHandler
开发者ID:ayush03agarwal,项目名称:connekt,代码行数:37,代码来源:XMPPChannelSupervisor.scala
示例2: MessageRouter
//设置package包名称以及导入依赖的类
package name.mikulskibartosz.demo.akka.router
import akka.actor.SupervisorStrategy.Restart
import akka.actor.{OneForOneStrategy, Actor, Props}
import akka.routing.{ActorRefRoutee, RoundRobinRoutingLogic, Router}
import name.mikulskibartosz.demo.akka.actors.QueryExecutor
import name.mikulskibartosz.demo.akka.messages.{ExecuteQuery, ServiceUnavailable}
import name.mikulskibartosz.demo.akka.service.Service
class MessageRouter(private val service: Service) extends Actor {
var router = {
val routees = Vector.fill(5) {
val r = context.actorOf(Props(new QueryExecutor(service)))
context watch r
ActorRefRoutee(r)
}
Router(RoundRobinRoutingLogic(), routees)
}
override def supervisorStrategy = OneForOneStrategy() {
case _ => Restart
}
def receive = {
case ExecuteQuery => router.route(ExecuteQuery, sender())
case ServiceUnavailable => context.parent ! ServiceUnavailable
}
}
开发者ID:mikulskibartosz,项目名称:demoAkkaAccessingUnreliableService,代码行数:30,代码来源:MessageRouter.scala
注:本文中的akka.routing.ActorRefRoutee类示例整理自Github/MSDocs等源码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。 |
请发表评论