我无法让 Akka 调度方法在 Heroku 中正常工作。它在本地运行良好,并将“心跳”打印到日志中。
这是有问题的文件:https ://github.com/magnusart/actor-test/blob/master/app/Global.scala和下面的片段。
override def onStart(app: Application) {
Logger.debug("Starting application")
Akka.system(app).scheduler.schedule(2 seconds, 10 seconds) {
Logger.debug("Heartbeat")
}
}
完整的应用程序在这里(为此目的而隔离,也在 actor-test.herokuapp.com 上)。 https://github.com/magnusart/actor-test
启动后发生的事情是我Starting application
在日志中看到,然后我看不到任何进一步的东西:
2012-05-26T16:29:40+00:00 heroku[web.1]: Starting process with command `target/start -Dhttp.port=43943 -Xmx384m -Xss512k -XX:+UseCompressedOops`
2012-05-26T16:29:41+00:00 app[web.1]: Play server process ID is 3
2012-05-26T16:29:42+00:00 app[web.1]: [debug] application - Starting application
2012-05-26T16:29:42+00:00 app[web.1]: [info] play - Starting application default Akka system.
2012-05-26T16:29:42+00:00 app[web.1]: [info] play - Application started (Prod)
2012-05-26T16:29:42+00:00 app[web.1]: [info] play - Listening for HTTP on port 43943...
所以预定的演员实际上似乎并没有开始(它当然在本地开始)。我在 Heroku Cedar 上。我感谢任何关于为什么这不起作用的提示,我错过了什么?
BR 马格努斯·安德森
更新 根据我的发现,这似乎是 Play 2 中的一个错误(我正在运行 2.0.1 版),并且与 Heroku 无关。我已经用相关信息更新了 Play 2 Lighthouse 门票。门票可以在这里找到:https ://play.lighthouseapp.com/projects/82401-play-20/tickets/448-play-dist-ignores-loggerxml#ticket-448-5