quartz基础学习(三)

转载:https://blog.csdn.net/jiangliubang/article/details/78508101  
七、TriggerListener和JobListener
1、listener是一个对象,用于监听scheduler中发生的事件,然后执行相应的操作;你可能已经猜到了,TriggerListeners接受与trigger相关的事件,JobListeners接受与jobs相关的事件。trigger相关的事件包括:trigger的触发、trigger错过触发(mis-fire)以及trigger的完成(即trigger触发的job执行完成)。org.quartz.TriggerListener接口
public interface TriggerListener {
    public String getName();
    public void triggerFired(Trigger trigger, JobExecutionContext context);
    public boolean vetoJobExecution(Trigger trigger, JobExecutionContext context);
    public void triggerMisfired(Trigger trigger);
    public void triggerComplete(Trigger trigger, JobExecutionContext context,
            int triggerInstructionCode);
}

job相关的事件包括:job即将执行的通知以及job执行完毕的通知。org.quartz.JobListener接口:
public interface JobListener {
    public String getName();
    public void jobToBeExecuted(JobExecutionContext context);
    public void jobExecutionVetoed(JobExecutionContext context);
    public void jobWasExecuted(JobExecutionContext context,
            JobExecutionException jobException);
}
2、使用自定义的listener:创建一个listener,只需要实现org.quartz.TriggerListener接口或者org.quartz.JobListener 接口即可;然后在运行时将listener注册到scheduler上,并且需要给listener取个名称(因为listener需要通过其getName()方法广播它的名称)。我们可以实现上面提到的接口,但更方便的方式是继承JobListenerSupport类或者TriggerListenerSupport类,只需重写需要的方法即可。listener是注册到scheduler的ListenerManager上的,与listener一同注册的还有一个Matcher对象,该对象用于描述listener期望接收事件的job或trigger。listener是在运行的时候注册到scheduler上的,而且不会与job和trigger一样保存在JobStore中。因为listener一般是应用的一个集成点(integration point),因此,应用每次运行的时候,listener都应该重新注册到scheduler上。
给一个job添加JobListener:
scheduler.getListenerManager().addJobListener(myJobListener, KeyMatcher.jobKeyEquals(new JobKey("myJobName", "myJobGroup")));
可以对matcher和key下的类进行静态导入,这样使得matcher的定义更加清晰:
import static org.quartz.JobKey.*;
import static org.quartz.impl.matchers.KeyMatcher.*;
import static org.quartz.impl.matchers.GroupMatcher.*;
import static org.quartz.impl.matchers.AndMatcher.*;
import static org.quartz.impl.matchers.OrMatcher.*;
import static org.quartz.impl.matchers.EverythingMatcher.*;
...etc.
可以对matcher和key下的类进行静态导入,这样使得matcher的定义更加清晰:
scheduler.getListenerManager().addJobListener(myJobListener, jobKeyEquals(jobKey("myJobName", "myJobGroup")));
给一个group下的所有job添加一个JobListener:
scheduler.getListenerManager().addJobListener(myJobListener, jobGroupEquals("myJobGroup"));
给两个group下的所有job添加一个JobListener:
scheduler.getListenerManager().addJobListener(myJobListener, or(jobGroupEquals("myJobGroup"), jobGroupEquals("yourGroup")));
给所有的job添加一个JobListener:
scheduler.getListenerManager().addJobListener(myJobListener, allJobs());
TriggerListener的注册过程与JobListener类似。Quartz的大部分用户都不使用listener,但如果应用需要对发生的事件感兴趣,当然可以让job显示通知应用,但显然listener更方便。
八、SchedulerListener
SchedulerListener与TriggerListener、JobListener类似,但它仅接收来自Scheduler自身的消息,而不一定是某个具体的trigger或job的消息。scheduler相关的消息包括:job/trigger的增加、job/trigger的删除、scheduler内部发生的严重错误以及scheduler关闭的消息等;org.quartz.SchedulerListener接口:
public interface SchedulerListener { 
    public void jobScheduled(Trigger trigger); 
    public void jobUnscheduled(String triggerName, String triggerGroup); 
    public void triggerFinalized(Trigger trigger); 
    public void triggersPaused(String triggerName, String triggerGroup); 
    public void triggersResumed(String triggerName, String triggerGroup); 
    public void jobsPaused(String jobName, String jobGroup); 
    public void jobsResumed(String jobName, String jobGroup); 
    public void schedulerError(String msg, SchedulerException cause); 
    public void schedulerStarted(); 
    public void schedulerInStandbyMode(); 
    public void schedulerShutdown(); 
    public void schedulingDataCleared();
}
SchedulerListener也是注册到scheduler的ListenerManager上的,任何实现了org.quartz.SchedulerListener接口的对象都可以是SchedulerListener(译者注:SchedulerListener与JobListener/TriggerListener一样,也可以继承SchedulerListenerSupport抽象类,重写感兴趣的方法即可)。
添加一个SchedulerListener:
scheduler.getListenerManager().addSchedulerListener(mySchedListener);
删除一个SchedulerListener:
scheduler.getListenerManager().removeSchedulerListener(mySchedListener);
 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值