java - 为使用存储的 actor 设置有界邮箱

标签 java scala akka messaging actor

我有一个依赖于存储的 Actor 。藏匿需要 UnboundedDequeBasedMailbox .是否可以将存储与 Bounded 一起使用邮箱?

正如 Arnaud 指出的那样,我的设置是:

Actor with UnrestrictedStash with RequiresMessageQueue[BoundedDequeBasedMessageQueueSemantics]

和配置:

akka {

    loggers = ["akka.event.slf4j.Slf4jLogger"]
    loglevel = INFO
    daemonic = on

    actor {
            mailbox {
                bounded-deque-based {
                    mailbox-type = "akka.dispatch.BoundedDequeBasedMailbox"
                    mailbox-capacity = 2000
                    mailbox-push-timeout-time = 5s
                }
                requirements {
                  "akka.dispatch.BoundedDequeBasedMessageQueueSemantics" = akka.actor.mailbox.bounded-deque-based
                }
            }
    }
}

错误是:

[ERROR] 2013/12/06 14:03:58.268 [r-4] a.a.OneForOneStrategy - DequeBasedMailbox required, got: akka.dispatch.UnboundedMailbox$MessageQueue
An (unbounded) deque-based mailbox can be configured as follows:
  my-custom-mailbox {
    mailbox-type = "akka.dispatch.UnboundedDequeBasedMailbox"
  }

akka.actor.ActorInitializationException: exception during creation
    at akka.actor.ActorInitializationException$.apply(Actor.scala:218) ~[akka-actor_2.10-2.2.0.jar:2.2.0]
    at akka.actor.ActorCell.create(ActorCell.scala:578) ~[akka-actor_2.10-2.2.0.jar:2.2.0]
    at akka.actor.ActorCell.invokeAll$1(ActorCell.scala:425) ~[akka-actor_2.10-2.2.0.jar:2.2.0]
    at akka.actor.ActorCell.systemInvoke(ActorCell.scala:447) ~[akka-actor_2.10-2.2.0.jar:2.2.0]
    at akka.dispatch.Mailbox.processAllSystemMessages(Mailbox.scala:262) ~[akka-actor_2.10-2.2.0.jar:2.2.0]
    at akka.dispatch.Mailbox.run(Mailbox.scala:218) ~[akka-actor_2.10-2.2.0.jar:2.2.0]
    at akka.dispatch.ForkJoinExecutorConfigurator$AkkaForkJoinTask.exec(AbstractDispatcher.scala:386) [akka-actor_2.10-2.2.0.jar:2.2.0]
    at scala.concurrent.forkjoin.ForkJoinTask.doExec(ForkJoinTask.java:260) [scala-library-2.10.2.jar:na]
    at scala.concurrent.forkjoin.ForkJoinPool$WorkQueue.runTask(ForkJoinPool.java:1339) [scala-library-2.10.2.jar:na]
    at scala.concurrent.forkjoin.ForkJoinPool.runWorker(ForkJoinPool.java:1979) [scala-library-2.10.2.jar:na]
    at scala.concurrent.forkjoin.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:107) [scala-library-2.10.2.jar:na]
Caused by: akka.actor.ActorInitializationException: DequeBasedMailbox required, got: akka.dispatch.UnboundedMailbox$MessageQueue
An (unbounded) deque-based mailbox can be configured as follows:
  my-custom-mailbox {
    mailbox-type = "akka.dispatch.UnboundedDequeBasedMailbox"
  }

    at akka.actor.ActorInitializationException$.apply(Actor.scala:218) ~[akka-actor_2.10-2.2.0.jar:2.2.0]
    at akka.actor.UnrestrictedStash$class.$init$(Stash.scala:82) ~[akka-actor_2.10-2.2.0.jar:2.2.0]
    at com.fg.mail.smtp.index.Indexer.<init>(Indexer.scala:38) ~[classes/:na]
    at com.fg.mail.smtp.Supervisor$$anonfun$preStart$1.apply(Supervisor.scala:20) ~[classes/:na]
    at com.fg.mail.smtp.Supervisor$$anonfun$preStart$1.apply(Supervisor.scala:20) ~[classes/:na]
    at akka.actor.CreatorFunctionConsumer.produce(Props.scala:369) ~[akka-actor_2.10-2.2.0.jar:2.2.0]
    at akka.actor.Props.newActor(Props.scala:323) ~[akka-actor_2.10-2.2.0.jar:2.2.0]
    at akka.actor.ActorCell.newActor(ActorCell.scala:534) ~[akka-actor_2.10-2.2.0.jar:2.2.0]
    at akka.actor.ActorCell.create(ActorCell.scala:560) ~[akka-actor_2.10-2.2.0.jar:2.2.0]
    ... 9 common frames omitted

如果我这样做 Props.withMailbox("bounded-deque-based")然后我得到

Caused by: akka.ConfigurationException: Mailbox Type [bounded-deque-based] not configured

回答:感谢 Arnaud:问题是配置,基于有界双端队列的配置 block 应该与 akka 配置 block 处于同一级别。 Documentation在这种情况下完全是误导......

akka {

    loggers = ["akka.event.slf4j.Slf4jLogger"]
    loglevel = INFO
    daemonic = on

    actor {
        mailbox {
            requirements {
                    "akka.dispatch.BoundedDequeBasedMessageQueueSemantics" = akka.actor.mailbox.bounded-deque-based
                  }
        }
    }
}

bounded-deque-based {
    mailbox-type = "akka.dispatch.BoundedDequeBasedMailbox"
    mailbox-capacity = 2000
    mailbox-push-timeout-time = 5s
}

最佳答案

根据Akka官方stash doc您可以决定使用不强制执行任何邮箱类型的 Stash 特征,请参阅 UnrestrictedStash .

如果您使用 UnrestrictedStash,您可以手动配置适当的邮箱,只要它扩展了 akka.dispatch.DequeBasedMessageQueueSemantics 标记特征。

您可以按照mailboxes doc 手动配置您的BoundedMailbox 邮箱。像这样:

bounded-mailbox {
  mailbox-type = "akka.dispatch.BoundedDequeBasedMailbox"
  mailbox-capacity = 1000
  mailbox-push-timeout-time = 10s
}

akka.actor.mailbox.requirements {
  "akka.dispatch.BoundedDequeBasedMessageQueueSemantics" = bounded-mailbox
}

我自己没有尝试过,但应该可以。

编辑:您使用的是什么版本的 Akka?看起来 stash trait 定义随着版本 2.2.0 发生了变化

关于java - 为使用存储的 actor 设置有界邮箱,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20419990/

相关文章:

java - 命名和目录 (JNDI) - 使用 JNDI 的陷阱是什么

scala - scala中的自动xml转换

scala - 从命令行运行时找不到包

scala - 在 akka 中手动创建 Actor 层次结构

java - Akka 输入流处理

返回arraylist的Java返回方法?

java - 我们可以在一个 Jenkins 中添加两个 Java 版本吗?

java - 如何在 J2EE 中进行动态 URL 重写

json - 如何将 float 组(无需序列化/反序列化)从 Scala (JeroMQ) 传输到 C (ZMQ)?

scala - akka中FastFuture有什么用