zoukankan      html  css  js  c++  java
  • Quartz任务调度(6)schedulerListener分版本超详细解析

    schedulerListener

    在我们的监听器实现类中,这个类中需实现的方法很多,不需要的可以给出空实现,下面是一些常用的用法:

    方法说明
    jobScheduled() Scheduler 在有新的 JobDetail 部署时调用此方法。
    jobUnscheduled() Scheduler 在有新的 JobDetail卸载时调用此方法
    triggerFinalized() 当一个 Trigger 来到了再也不会触发的状态时调用这个方法。除非这个 Job 已设置成了持久性,否则它就会从 Scheduler 中移除。
    triggersPaused() Scheduler 调用这个方法是发生在一个 Trigger 或 Trigger 组被暂停时。假如是 Trigger 组的话,triggerName 参数将为 null。
    triggersResumed() Scheduler 调用这个方法是发生成一个 Trigger 或 Trigger 组从暂停中恢复时。假如是 Trigger 组的话,triggerName 参数将为 null。
    jobsPaused() 当一个或一组 JobDetail 暂停时调用这个方法。
    jobsResumed() 当一个或一组 Job 从暂停上恢复时调用这个方法。假如是一个 Job 组,jobName 参数将为 null。
    schedulerError() Scheduler 的正常运行期间产生一个严重错误时调用这个方法。错误的类型会各式的,但是下面列举了一些错误例子:初始化 Job 类的问题,试图去找到下一 Trigger 的问题,JobStore 中重复的问题,数据存储连接的问题。我们可以使用 SchedulerException 的 getErrorCode() 或者 getUnderlyingException() 方法或获取到特定错误的更详尽的信息。
    schedulerShutdown() Scheduler 调用这个方法用来通知 SchedulerListener Scheduler 将要被关闭。

    1.x版本配置

    下面是一个1.+版本实例配置:

    package tool.job;
    
    import org.quartz.JobDetail;
    import org.quartz.SchedulerException;
    import org.quartz.SchedulerListener;
    import org.quartz.Trigger;
    
    public class MySchedulerListener implements SchedulerListener {
    
        @Override
        public void jobScheduled(Trigger trigger) {
            System.out.println("任务被部署时被执行");
        }
    
    
        @Override
        public void triggerFinalized(Trigger trigger) {
            System.out.println("任务完成了它的使命,光荣退休时被执行");
        }
    
        @Override
        public void jobAdded(JobDetail jobDetail) {
            System.out.println("一个新的任务被动态添加时执行");
        }
    
    
    
        @Override
        public void jobUnscheduled(String triggerName, String triggerGroup) {
            System.out.println("任务被卸载时被执行");
    
        }
    
        @Override
        public void triggersPaused(String triggerName, String triggerGroup) {
            System.out.println(triggerGroup + "所在组的全部触发器被停止时被执行");
        }
    
        @Override
        public void triggersResumed(String triggerName, String triggerGroup) {
            System.out.println(triggerGroup + "所在组的全部触发器被回复时被执行");
        }
    
        @Override
        public void jobDeleted(String jobName, String groupName) {
            System.out.println(groupName + "." + jobName + "被删除时被执行");
        }
    
        @Override
        public void jobsPaused(String jobName, String jobGroup) {
            System.out.println(jobGroup + "(一组任务)被暂停时被执行");
        }
    
        @Override
        public void jobsResumed(String jobName, String jobGroup) {
            System.out.println(jobGroup + "(一组任务)被回复时被执行");
        }
        @Override
        public void schedulerError(String msg, SchedulerException cause) {
            System.out.println("出现异常" + msg + "时被执行");
            cause.printStackTrace();
        }
    
        @Override
        public void schedulerInStandbyMode() {
            System.out.println("scheduler被设为standBy等候模式时被执行");
    
        }
    
        @Override
        public void schedulerStarted() {
            System.out.println("scheduler启动时被执行");
    
        }
    
        @Override
        public void schedulerShutdown() {
            System.out.println("scheduler关闭时被执行");
        }
    
        @Override
        public void schedulerShuttingdown() {
            System.out.println("scheduler正在关闭时被执行");
        }
    }

    下面是我们的测试方法,关于方法中没提到的类的配置可参考我前面系列的文章。

    public static void main(String args[]) throws SchedulerException {
        JobDetail pickNewsJob =new JobDetail("job1", "jgroup1", PickNewsJob.class); 
        JobDetail getHottestJob =new JobDetail("job2", "jgroup2", GetHottestJob.class);
        SimpleTrigger pickNewsTrigger = new SimpleTrigger("trigger1", "group1",1,2000);
        SimpleTrigger getHottestTrigger = new SimpleTrigger("trigger2", "group2",1,3000);
    
        SchedulerFactory schedulerFactory = new StdSchedulerFactory();
        Scheduler scheduler = schedulerFactory.getScheduler();
        JobListener myJobListener = new MyJobListener();
        /**********局部Job监听器配置**********/
        pickNewsJob.addJobListener("myJobListener");//这里的名字和myJobListener中getName()方法的名字一样
        scheduler.addJobListener(myJobListener);//向scheduler注册我们的监听器
        /*********全局Job监听器配置************/
    //      scheduler.addGlobalJobListener(myJobListener);//直接添加为全局监听器
    
        TriggerListener myTriggerListener = new MyTriggerListener();
        /**********局部Trigger监听器配置**********/
        pickNewsTrigger.addTriggerListener("myTriggerListener");
        scheduler.addTriggerListener(myTriggerListener);
        /*********全局Trigger监听器配置************/
    //      scheduler.addGlobalTriggerListener(myTriggerListener);//直接添加为全局监听器
        /************SchedulerListener配置*************/
        SchedulerListener mySchedulerListener = new MySchedulerListener();
        scheduler.addSchedulerListener(mySchedulerListener);
    
        scheduler.scheduleJob(pickNewsJob,pickNewsTrigger);
        scheduler.scheduleJob(getHottestJob,getHottestTrigger);
    
        scheduler.start();
    
    }

    运行方法,我们会看到:

    一个新的任务被动态添加时执行————SchedulerListener中的方法被调用
    任务被部署时被执行————SchedulerListener中的方法被调用
    一个新的任务被动态添加时执行————SchedulerListener中的方法被调用
    任务被部署时被执行————SchedulerListener中的方法被调用
    scheduler启动时被执行————SchedulerListener中的方法被调用
    Trigger 被触发了,此时Job 上的 execute() 方法将要被执行
    不否决Job,正常执行
    myJobListener触发对class tool.job.PickNewsJob的开始执行的监听工作,这里可以完成任务前的一些资源准备工作或日志记录
    在13:53:18扒取新闻
    在13:53:18根据文章的阅读量和评论量来生成我们的最热文章列表
    myJobListener触发对class tool.job.PickNewsJob结束执行的监听工作,这里可以进行资源销毁工作或做一些新闻扒取结果的统计工作
    Trigger 被触发并且完成了 Job 的执行,此方法被调用
    Trigger 被触发了,此时Job 上的 execute() 方法将要被执行
    不否决Job,正常执行
    myJobListener触发对class tool.job.PickNewsJob的开始执行的监听工作,这里可以完成任务前的一些资源准备工作或日志记录
    在13:53:20扒取新闻
    myJobListener触发对class tool.job.PickNewsJob结束执行的监听工作,这里可以进行资源销毁工作或做一些新闻扒取结果的统计工作
    Trigger 被触发并且完成了 Job 的执行,此方法被调用
    任务完成了它的使命,光荣退休时被执行————SchedulerListener中的方法被调用
    在13:53:21根据文章的阅读量和评论量来生成我们的最热文章列表
    任务完成了它的使命,光荣退休时被执行————SchedulerListener中的方法被调用

    2.x 版本配置

    2.+版本与1.+版本的主要区别是新添加了一些方法,并将jobName,groupName参数对换成了JobKey等。
    下面是配置实例:

    package tool.job;
    
    import org.quartz.JobDetail;
    import org.quartz.JobKey;
    import org.quartz.SchedulerException;
    import org.quartz.SchedulerListener;
    import org.quartz.Trigger;
    import org.quartz.TriggerKey;
    
    public class MySchedulerListener implements SchedulerListener {
    
        @Override
        public void jobScheduled(Trigger trigger) {
            System.out.println("任务被部署时被执行");
        }
    
        @Override
        public void jobUnscheduled(TriggerKey triggerKey) {
            System.out.println("任务被卸载时被执行");
        }
    
        @Override
        public void triggerFinalized(Trigger trigger) {
            System.out.println("任务完成了它的使命,光荣退休时被执行");
        }
    
        @Override
        public void triggerPaused(TriggerKey triggerKey) {
            System.out.println(triggerKey + "(一个触发器)被暂停时被执行");
        }
    
        @Override
        public void triggersPaused(String triggerGroup) {
            System.out.println(triggerGroup + "所在组的全部触发器被停止时被执行");
        }
    
        @Override
        public void triggerResumed(TriggerKey triggerKey) {
            System.out.println(triggerKey + "(一个触发器)被恢复时被执行");
        }
    
        @Override
        public void triggersResumed(String triggerGroup) {
            System.out.println(triggerGroup + "所在组的全部触发器被回复时被执行");
        }
    
        @Override
        public void jobAdded(JobDetail jobDetail) {
            System.out.println("一个JobDetail被动态添加进来");
        }
    
        @Override
        public void jobDeleted(JobKey jobKey) {
            System.out.println(jobKey + "被删除时被执行");
        }
    
        @Override
        public void jobPaused(JobKey jobKey) {
            System.out.println(jobKey + "被暂停时被执行");
    
        }
    
        @Override
        public void jobsPaused(String jobGroup) {
            System.out.println(jobGroup + "(一组任务)被暂停时被执行");
        }
    
        @Override
        public void jobResumed(JobKey jobKey) {
            System.out.println(jobKey + "被恢复时被执行");
        }
    
        @Override
        public void jobsResumed(String jobGroup) {
            System.out.println(jobGroup + "(一组任务)被回复时被执行");
        }
    
        @Override
        public void schedulerError(String msg, SchedulerException cause) {
            System.out.println("出现异常" + msg + "时被执行");
            cause.printStackTrace();
        }
    
        @Override
        public void schedulerInStandbyMode() {
            System.out.println("scheduler被设为standBy等候模式时被执行");
    
        }
    
        @Override
        public void schedulerStarted() {
            System.out.println("scheduler启动时被执行");
    
        }
    
        @Override
        public void schedulerStarting() {
            System.out.println("scheduler正在启动时被执行");
    
        }
    
        @Override
        public void schedulerShutdown() {
            System.out.println("scheduler关闭时被执行");
        }
    
        @Override
        public void schedulerShuttingdown() {
            System.out.println("scheduler正在关闭时被执行");
    
        }
    
        @Override
        public void schedulingDataCleared() {
            System.out.println("scheduler中所有数据包括jobs, triggers和calendars都被清空时被执行");
        }
    
    }

    在2.+版本中,我们通过以下方式注册我们的监听器:

    SchedulerListener mySchedulerListener = new MySchedulerListener();
    scheduler.getListenerManager().addSchedulerListener(mySchedulerListener);

    其它测试代码可参考我前面系列文章的,测试结果和之前1.+版本内容基本一致

  • 相关阅读:
    Arbitrage
    Big Event in HDU
    敌兵布阵
    Eddy's picture
    A Walk Through the Forest 最短路径+深搜
    Holding Bin-Laden Captive! 母函数
    Moving Tables 贪心
    Fire Net
    Number Sequence
    Find your present! map
  • 原文地址:https://www.cnblogs.com/deityjian/p/11681136.html
Copyright © 2011-2022 走看看