如何使用Akka 2.3.x运行Play 2.2.x?

时间:2014-04-01 07:56:16

标签: playframework akka playframework-2.2 akka-persistence

有没有办法结合akka 2.3和2.2?现在我在运行这样的应用程序时得到了AbstractMethodError。我需要在一个应用程序中同时使用它们,因为Akka 2.3带有非常有用的akka​​持久性模块,它非常可靠(与它的前身相反),这种可靠性在我的情况下非常重要。我尝试从源代码编译游戏2.2.2并将akka依赖项改为2.3但我仍然得到同样的错误:

[ERROR] [04/01/2014 09:42:26.105] [play-akka.actor.default-dispatcher-6] [ActorSystem(play)] Uncaught error from thread [play-akka.actor.default-dispatcher-6] shutting down JVM since 'akka.jvm-exit-on-fatal-error' is enabled
 java.lang.AbstractMethodError
    at akka.actor.ActorCell.receiveMessage(ActorCell.scala:516)
    at akka.actor.ActorCell.invoke(ActorCell.scala:487)
    at akka.dispatch.Mailbox.processMailbox(Mailbox.scala:238)
    at akka.dispatch.Mailbox.run(Mailbox.scala:220)
    at akka.dispatch.ForkJoinExecutorConfigurator$AkkaForkJoinTask.exec(AbstractDispatcher.scala:393)
    at scala.concurrent.forkjoin.ForkJoinTask.doExec(ForkJoinTask.java:260)
    at scala.concurrent.forkjoin.ForkJoinPool$WorkQueue.runTask(ForkJoinPool.java:1339)
    at scala.concurrent.forkjoin.ForkJoinPool.runWorker(ForkJoinPool.java:1979)
    at scala.concurrent.forkjoin.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:107)
    at scala.concurrent.forkjoin.ForkJoinTask.doExec(ForkJoinTask.java:260)
    at scala.concurrent.forkjoin.ForkJoinPool$WorkQueue.runTask(ForkJoinPool.java:1339)
    at scala.concurrent.forkjoin.ForkJoinPool.runWorker(ForkJoinPool.java:1979)
    at scala.concurrent.forkjoin.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:107)

2 个答案:

答案 0 :(得分:9)

Akka 2.3和Play 2.2只是二进制不兼容,这意味着您可以使用Akka 2.3作为依赖项编译Play 2.2并将其发布到您当地的常春藤或公司存储库。

在我的情况下,修补的Play版本没有发生AbstractMethodError。尝试以这种方式修补:

  1. 查看已标记的Play版本的源代码,例如https://github.com/playframework/playframework/releases/tag/2.2.2
  2. 切换到framework文件夹(这是带有project子目录的sbt项目)
  3. 更改Play和Akka依赖项的版本号,例如https://github.com/schleichardt/Play20/commit/14b45c44924ce5b3ef2159c772bc5b0544c94658
  4. sbt publishLocalsbt publish,对于后者,您需要调整publishMavenStyle := true
  5. 中的发布{Ivy,Maven}存储库和framework/project/Build.scala
  6. (可选)除非您已将Play的修补程序版本发布到本地Ivy存储库(使用publishLocal),否则您需要将解析程序添加到build.sbtproject/plugins.sbt
  7. project/plugins.sbt中设置已修补的Play sbt插件,例如addSbtPlugin("com.typesafe.play" % "sbt-plugin" % "2.2.2-akka-2.3.1")
  8. 演示在https://github.com/schleichardt/event-sourcing-with-the-play-framework/tree/bf171720c43a1349555726cb11cffae4d967cc4b。已修补的Play版本的源代码位于https://github.com/schleichardt/Play20/tree/2.2.2-akka-2.3.1

    有关Akka 2.3编译Play的问题,请参阅https://stackoverflow.com/a/22651261/1575096,Jeff May无法使用WS库。

    请记住,其他库(例如带有Play迭代的ReactiveMongo)也可能依赖于Play库,并且可能会将未修补的版本加载到类路径中。 在这种情况下,像"group" %% "library" % "version" exclude("com.typesafe.play", "play")这样的东西会有所帮助。如果是ReactiveMongo,你也需要为Akka 2.3编译它。

    使用sbt 'show libraryDependencies',您可以检查实际的依赖关系及其版本。

答案 1 :(得分:6)

不幸的是,您必须等待Play团队发布与Akka 2.3兼容的版本,或者在他们的邮件列表中询问有关如何正确构建Play发行版的说明(因为您似乎实际上并没有使用重建的JAR)。