当前位置: 首页>>代码示例>>Scala>>正文


Scala Router类代码示例

本文整理汇总了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 
开发者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.Router类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。