如何保证Actor的响应时间?

时间:2013-04-27 17:05:21

标签: scala concurrency akka actor

这是my previous question的后续行动:

假设我有一个actor,每秒处理X个请求。但有时会有突发,客户端每秒发送Y > X个请求。现在我必须保证客户端在给定的超时时间内收到响应(ether 成功超时状态)。

假设我使用Scala和Akka你会建议实现它吗?

2 个答案:

答案 0 :(得分:3)

首先,一个显示超时处理的小代码示例:

import akka.actor._
import akka.util.Timeout
import scala.concurrent.duration._
import akka.pattern._
import scala.util._
import java.util.concurrent.TimeoutException

object TimeoutTest {
  def main(args: Array[String]) {
    val sys = ActorSystem("test-system")
    implicit val timeout = Timeout(2 seconds)
    implicit val ec = sys.dispatcher
    val ref = sys.actorOf(Props[MyTestActor])

    val fut = ref ? "foo"
    fut onComplete{
      case Success(value) => println("Got success")
      case Failure(ex:TimeoutException) => println("Timed out")
      case Failure(ex) => println("Got other exception: " + ex.getMessage)
    }
  }
}

class MyTestActor extends Actor{
  def receive = {
    case _ =>
      Thread.sleep(3000)
      sender ! "bar"
  }
}

你可以在这个例子中看到,我指定{2}的ask超时,我的演员在响应前3秒睡觉。在这种情况下,我将始终获得Failure包裹TimeoutException。现在,超时处理不是Scala的Future类本机,但幸运的是,Akka为其ask操作添加了超时支持。在幕后,当您执行ask时,Akka会创建两个Promises;一个可以由响应消息的actor完成,另一个由HashedWheelTimer类中的计时器任务完成。然后,Akka从这两个Futures个实例中获取Promise并将其与Future.firstCompletedOf组合成一个,以便从Future调用中返回的?可以是无论先发生什么事情,都可以通过接收消息的演员的响应或超时完成。

答案 1 :(得分:1)

这取决于你如何使用演员。如果你正在使用'问' (如actor ? msg),您将收到一个在指定时间后超时的未来。

请参阅http://doc.akka.io/docs/akka/snapshot/scala/futures.html(与演员合作)

您可以在未来添加onFailure挂钩,以便在将来超时时向客户端发送错误响应。

未来api:http://www.scala-lang.org/api/current/index.html#scala.concurrent.Future