java 调度框架quartz

 

核心代码如下:                      

public class SchedulerTest {  
   public static void main(String[] args) {  
     //创建schedulerFactory类
       SchedulerFactory schedulerfactory=new StdSchedulerFactory();  
       Scheduler scheduler=null;  
       try{  
     //第一步:通过schedulerFactory获取一个调度器  
           scheduler=schedulerfactory.getScheduler();  
     //第二步:创建jobDetail实例,绑定Job实现类  
   //指明job的名称,所在组的名称,以及绑定job类--这里是要定时执行的那个类,需要实现org.quartz.Job接口  
           JobDetail job=JobBuilder.newJob(MyJob.class)
              .withIdentity("job1", "jgroup1").build();    //第三步:定义调度触发规则:    //规则一:使用simpleTrigger规则--一般用于循环执行    /* Trigger trigger=TriggerBuilder.newTrigger()
               .withIdentity("simpleTrigger", "triggerGroup")
               //间隔时间    
.withSchedule(SimpleScheduleBuilder.repeatSecondlyForever(1)
               .withRepeatCount(8)) //运行次数
     .startNow().build(); */    //规则二:使用cornTrigger规则 每天10点42分 --一般由用于定时执行 Trigger trigger=TriggerBuilder.newTrigger()
              .withIdentity("simpleTrigger", "triggerGroup")
               //这个规则下面解释    .withSchedule(CronScheduleBuilder.cronSchedule(
"0 42 10 * * ? *"))    .startNow().build();    //第四步:把作业和触发器注册到任务调度中 scheduler.scheduleJob(job, trigger);    //最后第五步:启动调度 scheduler.start(); }catch(Exception e){ e.printStackTrace(); } } }
 

规则一:使用simpleTrigger的详解

规则一用的是SimpleScheduleBuilder去设置,主要设置2个参数间隔时间运行次数

1.间隔时间的设置方法如下:

可以按照毫秒,秒 ,分钟,小时去配置;

2.运行次数的设置方法如下:

withRepeatCount()设置任务需要执行的总次数。

下边那个repeatForever()这个方法单独说一下,这个方法会把repeatCount设置为-1,意思是一致循环下去。

3.间隔时间和运行次数一起设置:

这些方法看方法名字差不多就知道什么意思了,比如repeatMinutelyForever(10) 每隔10分钟,一致循环执行下去。

这些方法内部基本调用的是前面2个方法,具体解释点进去看注释吧。

 

规则二:使用cornTrigger的详解

字段     允许值         允许的特殊字符    
秒       0-59            , - * /    
分       0-59            , - * /    
小时      0-23            , - * /    
日期      1-31          , - * ? / L W C    
月份    1-12 或者 JAN-DEC       , - * /    
星期    1-7 或者 SUN-SAT      , - * ? / L C #    
年(可选)    留空, 1970-2099      , - * /    
 

特殊字符解释:

*    表示所有值;    
?    表示未说明的值,即不关心它为何值;    
-    表示一个指定的范围;    
,    表示附加一个可能值;    
/    符号前表示开始时间,符号后表示每次递增的值;
 

表达式   意义    

"0 0 12 * * ?"        每天12点触发    
--------这三个设置一样的---------------
"0 15 10 ? * *"      每天10:15触发    
"0 15 10 * * ?"      每天10:15触发    
"0 15 10 * * ? *"      每天10:15触发
 
0 08 * * * ?     每个小时08分钟的时候触发一次
   
"0 15 10 * * ? 2005"          2005年的每天上午10:15触发    
"0 * 14 * * ?"           在每天下午2点到下午2:59期间的每1分钟触发    
"0 0/5 14 * * ?"             在每天下午2点到下午2:55期间的每5分钟触发     
"0 0/5 14,18 * * ?"          在每天下午2点到2:55期间和下午6点到6:55期间的每5分钟触发     
"0 0-5 14 * * ?"                  在每天下午2点到下午2:05期间的每1分钟触发    
"0 10,44 14 ? 3 WED"         每年三月的星期三的下午2:10和2:44触发    
"0 15 10 ? * MON-FRI"        周一至周五的上午10:15触发    
"0 15 10 15 * ?"            每月15日上午10:15触发    
"0 15 10 L * ?"           每月最后一日的上午10:15触发    
"0 15 10 ? * 6L"            每月的最后一个星期五上午10:15触发      
"0 15 10 ? * 6L 2002-2005"       2002年至2005年的每月的最后一个星期五上午10:15触发    
"0 15 10 ? * 6#3"          每月的第三个星期五上午10:15触发 
 
  
maven 配置

<dependency>
  <groupId>org.quartz-scheduler</groupId>
  <artifactId>quartz</artifactId>
  <version>2.2.1</version>
</dependency>

 

参考文章:http://blog.csdn.net/yuebinghaoyuan/article/details/9045471

转载于:https://www.cnblogs.com/yanghaolie/p/6656950.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
基于xxl-job改造,支持1.6jdk。改分布式任务调度特性如下: 1、简单:支持通过Web页面对任务进行CRUD操作,操作简单,一分钟上手; 2、动态:支持动态修改任务状态、暂停/恢复任务,以及终止运行中任务,即时生效; 3、调度中心HA(中心式):调度采用中心式设计,“调度中心”基于集群Quartz实现,可保证调度中心HA; 4、执行器HA(分布式):任务分布式执行,任务"执行器"支持集群部署,可保证任务执行HA; 5、任务Failover:执行器集群部署时,任务路由策略选择"故障转移"情况下调度失败时将会平滑切换执行器进行Failover; 6、一致性:“调度中心”通过DB锁保证集群分布式调度的一致性, 一次任务调度只会触发一次执行; 7、自定义任务参数:支持在线配置调度任务入参,即时生效; 8、调度线程池:调度系统多线程触发调度运行,确保调度精确执行,不被堵塞; 9、弹性扩容缩容:一旦有新执行器机器上线或者下线,下次调度时将会重新分配任务; 10、邮件报警:任务失败时支持邮件报警,支持配置多邮件地址群发报警邮件; 11、状态监控:支持实时监控任务进度; 12、Rolling执行日志:支持在线查看调度结果,并且支持以Rolling方式实时查看执行器输出的完整的执行日志; 13、GLUE:提供Web IDE,支持在线开发任务逻辑代码,动态发布,实时编译生效,省略部署上线的过程。支持30个版本的历史版本回溯。 14、数据加密:调度中心和执行器之间的通讯进行数据加密,提升调度信息安全性; 15、任务依赖:支持配置子任务依赖,当父任务执行结束且执行成功后将会主动触发一次子任务的执行, 多个子任务用逗号分隔;

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值