gpt4 book ai didi

scala - Play framework 2.0 - deadLetters 而不是 Actor

转载 作者:行者123 更新时间:2023-12-04 21:40:49 24 4
gpt4 key购买 nike

出于学习目的,我正在尝试实现一个从远程 Actor 获取数据的简单 Play 应用程序。 Actor 的代码如下:

import akka.actor.{Props, ActorSystem, Actor}

class NumbersServer extends Actor {
var number = 0
protected def receive = {
case 'next => {
number += 1
number
}
case 'reset => number = 0
case 'exit => context.stop(self)
case 'get => sender ! number
}
}

object Server {
def main(args: Array[String]) {
val system = ActorSystem("ServerSystem")
val server = system.actorOf(Props[NumbersServer], "server")
}
}

我把它打包成一个jar,然后从命令行启动它。如果我尝试从另一个窗口打开的 Scala 控制台向该参与者发送消息,一切正常。现在我想从 Play 框架中获取 Actor 。在Application对象我定义了以下方法:

def numbers = Action {
Ok(views.html.numbers(Client.actor.path.name))
}

然后在models包我定义了客户端对象:

object Client {
import play.api.Play.current
val actor = Akka.system.actorFor("akka://ServerSystem@127.0.0.1:2552/user/server")
}

numbers.html.scala文件:

@(message: String)

@main("Header") {
<h1>@message</h1>
}

所以我希望当我转到 127.0.0.1:9000/numbers 时,我会得到一个页面,其中包含服务器参与者的路径。而不是这个,我得到 <h1>deadLetters</h1> .我做错了什么以及应该如何正确完成?

最佳答案

请按照给出的配置

https://groups.google.com/forum/#!topic/akka-user/Vw-B8nQeagk

同时添加 akka-remote 依赖

val appDependencies = Seq(
"com.typesafe.akka" % "akka-remote" % "2.0.2"
)

关于scala - Play framework 2.0 - deadLetters 而不是 Actor,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10040503/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com