gpt4 book ai didi

scala - 如何在 Play Framework 2.4.2 scala 中正确安排任务?

转载 作者:行者123 更新时间:2023-12-04 05:02:59 25 4
gpt4 key购买 nike

尝试在 Play Framework 2.4.2 Scala 中安排这样的任务没有运气:

import akka.actor.Actor
import play.api.libs.concurrent.Akka
import scala.concurrent.duration._
import play.api.Play.current
import scala.concurrent.ExecutionContext.Implicits.global

class Scheduler extends Actor {

override def preStart() {
val dbupdate = Akka.system.scheduler.schedule(
0.microseconds, 5.minutes, self, "update")
val pictureClean = Akka.system.scheduler.schedule(
0.microseconds, 30.minutes, self, "clean")
}

def receive = {
case "update" => updateDB()
case "clean" => clean()
}

def updateDB(): Unit ={
Logger.debug("updates running")
}

def clean(): Unit ={
Logger.debug("cleanup running")
}
}

控制台中没有打印任何内容。我做错了什么?

最佳答案

行。这是我构建的调度程序的工作代码:
模块:

class JobModule extends AbstractModule with AkkaGuiceSupport {
def configure() = {
bindActor[SchedulerActor]("scheduler-actor")
bind(classOf[Scheduler]).asEagerSingleton()
}
}

调度器:
class Scheduler @Inject() (val system: ActorSystem, @Named("scheduler-actor") val schedulerActor: ActorRef)(implicit ec: ExecutionContext)
{
system.scheduler.schedule(
0.microseconds, 5.minutes, schedulerActor, "update")
system.scheduler.schedule(
30.minutes, 30.days, schedulerActor, "clean")
}

Actor :
@Singleton
class SchedulerActor @Inject() (updater: Updater) extends Actor {
def receive = {
case "update" => updateDB()
case "clean" => clean()
}

def updateDB(): Unit ={
Logger.debug("updates running")
}

def clean(): Unit ={
Logger.debug("cleanup running")
}
}

您还需要在 application.conf 中添加您的模块:
play.modules.enabled += "modules.JobModule"

希望这会对某人有所帮助

关于scala - 如何在 Play Framework 2.4.2 scala 中正确安排任务?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31679563/

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