Akka-quartz调度程序永远不会触发我的演员

时间:2013-11-01 13:03:50

标签: quartz-scheduler akka

我正在尝试使用akka-quartz-scheduler定期触发清理事件。我让调度程序将消息发送给actor,但仅当没有与日程表关联的日历时。每当我将日历附加到日程表时,演员都不会收到任何消息。

这是与akka-quartz-scheduler相关的application.conf部分。如果我删除该行

calendars = [“Minimal”]“

从配置中,我的演员被触发了。如果我离开该行,则不会调用任何演员。

akka {
    quartz {
        defaultTimezone = "Europe/Oslo"
        schedules {
            NowAndThen {
                description ="Delete temp files now and then, eg every hour"
                expression = "*/10 * * * * ?"
                calendars = ["Minimal"]
            }
        }
        calendars {

            Minimal {
                type = Daily
                exclude {
                    startTime = "15:00"
                    endTime   = "15:01"
                }
            }   

        }
    }
}

我正在使用Global.java中的playframework应用程序初始化扩展:

import akka.actor.ActorRef;
import akka.actor.ActorSystem;
import akka.actor.Extension;
import akka.actor.Props;
import com.typesafe.akka.extension.quartz.QuartzSchedulerExtension;
import play.Application;
import play.GlobalSettings;
import play.Logger;
import play.libs.Akka;
import uttrekk.CleanupRunner;

public class Global extends GlobalSettings {

  public void onStart(Application app) {
    AkkaStartUp.startup(app);
  }

  static class AkkaStartUp {

    public static void startup(Application app) {
      // Starter autoamtiske avelveringer norges eiendommer
      ActorSystem system = Akka.system();

      ActorRef cleanupRef =system.actorOf(new Props(CleanupRunner.class));

    QuartzSchedulerExtension scheduler = (QuartzSchedulerExtension) QuartzSchedulerExtension.get(system);
    scheduler.schedule("NowAndThen",cleanupRef,"Clean");

    }
  }
}

actor实现类似于以下内容:

package uttrekk;

import akka.actor.UntypedActor;
import play.Logger;
import util.NewProperties;

import java.io.File;
import java.io.FilenameFilter;

public class CleanupRunner extends UntypedActor {

  @Override
  public void onReceive(Object message) throws Exception {
    Logger.info("Running cleanup of temporary files");
  }
}

1 个答案:

答案 0 :(得分:3)

在日历初始化期间出现问题。 检查QuartzSchedulerExtension类中的第245行: scheduler.addCalendar(name.toUpperCase,calendar,true,true)

日历是使用UpperCase添加的,因此Quartz从未找到它,因此产生的工作没有被触发。 如果您使用UpperCase名称在akka配置中定义日历,它应该可以工作。