本文整理汇总了Scala中akka.routing.Router类的典型用法代码示例。如果您正苦于以下问题:Scala Router类的具体用法?Scala Router怎么用?Scala Router使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了Router类的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
示例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
}
}