当前位置: 首页 > 知识库问答 >
问题:

使用Akka调度器处理期货

穆旭尧
2023-03-14

我有一个基于喷雾的HTTP服务。我有一个在这个HTTP应用程序内部运行的流。现在由于这个流要做大量的I/O,所以我决定使用一个单独的线程池。我查阅了Akka文档,看看我可以做些什么来使我的线程池是可配置的。我在Akka遇到了调度器的概念。所以我尝试在application.conf中使用它如下所示:

akka {
  io-dispatcher {
    # Dispatcher is the name of the event-based dispatcher
    type = Dispatcher
    # What kind of ExecutionService to use
    executor = "fork-join-executor"
    # Configuration for the fork join pool
    fork-join-executor {
      # Min number of threads to cap factor-based parallelism number to
      parallelism-min = 2
      # Parallelism (threads) ... ceil(available processors * factor)
      parallelism-factor = 2.0
      # Max number of threads to cap factor-based parallelism number to
      parallelism-max = 10
    }
    # Throughput defines the maximum number of messages to be
    # processed per actor before the thread jumps to the next actor.
    # Set to 1 for as fair as possible.
    throughput = 20
  }
}

在我的执行元中,我尝试将此配置查找为:

context.system.dispatchers.lookup("akka.io-dispatcher")

当我运行我的服务时,我得到以下错误:

[ERROR] [05/03/2016 12:59:08.673] [my-app-akka.actor.default-dispatcher-2] [akka://my-app/user/myAppSupervisorActor] Dispatcher [akka.io-dispatcher] not configured
akka.ConfigurationException: Dispatcher [akka.io-dispatcher] not configured
    at akka.dispatch.Dispatchers.lookupConfigurator(Dispatchers.scala:99)
    at akka.dispatch.Dispatchers.lookup(Dispatchers.scala:81)

共有1个答案

汪胡非
2023-03-14

配置正确。您需要做的只是将加载的配置文件传递给Akka ActorSystem,如下所示:

ActorSystem("yourActorSystem", ConfigFactory.load())
 类似资料:
  • 考虑以下代码位: 计算机结果将在未来产生,那么val的引入将如何防止我将结果发送给错误的发件人?假设我有一个完全不同的发送者(发送者1和发送者2)。 Sender1 首先发送一条消息,然后发送 Sender2。如果没有上述方法中的 val,我清楚地看到我的 Sender2 有可能获得实际上针对 Sender1 的结果。 我不明白的是,val的引入将如何阻止我刚才描述的场景?

  • 我有以下代码块调用两个请求略有延迟。 在actor1和actor2中,我调用了一个REST请求,该请求返回一个cookie和响应消息。我在这里的意图是延迟发送与actor2对应的REST请求。然而,我从日志中观察到,请求立即从两个参与者发送,只有响应处理(在两个未来之间)延迟10秒。这是Akka中调度器的预期行为吗?如果我想在上述情况下延迟两个参与者之间的请求启动,我可以使用线程。睡觉(我在某个地

  • 我正在寻找最好的解决方案,以创建一个java web应用程序,以生成Excel/PDF格式的报告。类似于Google Adwords的东西,用户可以创建日程报告,并在以后生成报告时下载。 我正在考虑开发一个java应用程序,在其中用户记录,选择一个预先定义的报告,并提供输入参数(如报告日期等),这个请求将被排队或保存为Quarts作业(首选持久队列)。一个作业将监视队列/作业并执行该作业,生成报告

  • 在阅读了Akka的文档和网上的一些帖子之后,我仍然对路由器和调度器之间的关系没有一个清楚的认识。 1)路由器是否总是使用dispatcher向路由进行调度?路由器是否可以不使用dispatcher完成其工作? 2)如果配置中没有定义额外的调度器,我的理解是将使用默认调度器。在我的actor系统中,我有一个集群,其中有两个生产者actor使用路由器actor和三个消费者actor。生产者和消费者都运

  • 我在Java web应用程序中有一个分层体系结构。UI层只是Java,服务是Akka类型的actor,外部服务调用(WS、DB等)包装在Hystrix命令中。 问题是,我想释放服务参与者正在使用的线程,而只是绑定Hystrix使用的线程。但是java的未来阻止了这一点,因为我必须阻止它的完成。我能想到的唯一选项(我不确定我喜欢)是不断地轮询Java future(一个或多个),并在Java fut