【发布时间】:2021-08-13 13:35:12
【问题描述】:
我正在尝试使用这个 scala redis 库 etaty,它在创建它的 RedisClient 对象时需要一个隐式的 akka.actor.ActorSystem。我在 Behaviors.setup 方法中使用了context.system.classicSystem 来提供所需的隐式。
这是我的代码
def apply(): Behavior[Command] = Behaviors.setup { context =>
implicit val system = context.system
implicit val classic = context.system.classicSystem
lazy val redis = RedisClient(
host = host,
port = port
)
但是,我在日志中收到此错误。
java.lang.UnsupportedOperationException: cannot create top-level actor [RedisClient-$a] from the outside on ActorSystem with custom user guardian
at akka.actor.ActorSystemImpl.actorOf(ActorSystem.scala:895)
at redis.RedisClientActorLike.<init>(Redis.scala:41)
at redis.RedisClient.<init>(Redis.scala:86)
at ng.logicbud.deidara.core.db.redis.RedisDbService$.redis$lzycompute$1(RedisDbService.scala:34)
at ng.logicbud.deidara.core.db.redis.RedisDbService$.redis$1(RedisDbService.scala:34)
at ng.logicbud.deidara.core.db.redis.RedisDbService$.$anonfun$apply$2(RedisDbService.scala:62)
at akka.actor.typed.internal.BehaviorImpl$ReceiveMessageBehavior.receive(BehaviorImpl.scala:152)
at akka.actor.typed.Behavior$.interpret(Behavior.scala:274)
at akka.actor.typed.Behavior$.interpretMessage(Behavior.scala:230)
at akka.actor.typed.internal.adapter.ActorAdapter.handleMessage(ActorAdapter.scala:129)
at akka.actor.typed.internal.adapter.ActorAdapter.aroundReceive(ActorAdapter.scala:106)
at akka.actor.ActorCell.receiveMessage(ActorCell.scala:577)
at akka.actor.ActorCell.invoke(ActorCell.scala:547)
at akka.dispatch.Mailbox.processMailbox(Mailbox.scala:270)
at akka.dispatch.Mailbox.run(Mailbox.scala:231)
at akka.dispatch.Mailbox.exec(Mailbox.scala:243)
at java.base/java.util.concurrent.ForkJoinTask.doExec(ForkJoinTask.java:290)
at java.base/java.util.concurrent.ForkJoinPool$WorkQueue.topLevelExec(ForkJoinPool.java:1020)
at java.base/java.util.concurrent.ForkJoinPool.scan(ForkJoinPool.java:1656)
at java.base/java.util.concurrent.ForkJoinPool.runWorker(ForkJoinPool.java:1594)
at java.base/java.util.concurrent.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:183)
【问题讨论】:
-
AFAIC 在 lib (github.com/etaty/rediscala) 的文档中,他们实例化了一个无类型/经典的隐式,如下所示:
implicit val akkaSystem = akka.actor.ActorSystem()你试过了吗? -
是的,我做到了。我已经用我的代码更新了问题。
标签: scala redis akka akka-typed