• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

Scala Router类代码示例

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

本文整理汇总了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;未经允许,请勿转载。


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
Scala OptionalSourceMapper类代码示例发布时间:2022-05-23
下一篇:
Scala ServerApp类代码示例发布时间:2022-05-23
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap