zoukankan      html  css  js  c++  java
  • java定时任务Quartz Demo(2.X)

    直接上代码

    public class HelloQuartz implements Job{

    @Override

    public void execute(JobExecutionContext Jec) throws JobExecutionException {

    // TODO Auto-generated method stub

    System.out.println(Jec.getTrigger().getEndTime());

    System.out.println("hello quartz : " + new Date());

    }

    }

    public class SimpleExample {

    public void run_helloQuartz() throws Exception{

    // 通过SchedulerFactory获取一个调度器实例

    SchedulerFactory sf = new StdSchedulerFactory();

    //scheduler 调度程序

    Scheduler sched = sf.getScheduler();

    // 通过过JobDetail封装HelloQuartz,

    //同时指定Job在Scheduler中所属组及名称,这里,组名为group1,而名称为job1。  

    JobDetail job = JobBuilder.newJob(HelloQuartz.class).withIdentity("job1", "group1").build();

    // 创建一个SimpleTrigger实例,指定该Trigger在Scheduler中所属组及名称。  

            // 接着设置调度的时间规则.当前时间运行

    //触发器

    Trigger trigger = TriggerBuilder.newTrigger().withIdentity("trigger1", "group1").

    withSchedule(CronScheduleBuilder.cronSchedule("0/1 * * * * ?")).build();

    // 注册并进行调度  

            sched.scheduleJob(job, trigger);

            sched.start();

            //调度器停止运行  

            sched.shutdown(true);  

    }

    }

    package com.hhx.quartz;

    public class Main {

    public static void main(String[] args) throws Exception {

    // TODO Auto-generated method stub

    SimpleExample example = new SimpleExample();  

            example.run_helloQuartz();

    }

    }

    1)Cron表达式的格式:秒 分 时 日 月 周 年(可选)。

                   字段名                 允许的值                        允许的特殊字符  

                   秒                         0-59                               , - * /  

                   分                         0-59                               , - * /  

                   小时                   0-23                               , - * /  

                   日                         1-31                               , - * ? / L W C  

                   月                         1-12 or JAN-DEC          , - * /  

                   周几                     1-7 or SUN-SAT            , - * ? / L C #  

                   年 (可选字段)     empty, 1970-2099      , - * /

                   “?”字符:表示不确定的值

                   “,”字符:指定数个值

                   “-”字符:指定一个值的范围

                   “/”字符:指定一个值的增加幅度。n/m表示从n开始,每次增加m

                   “L”字符:用在日表示一个月中的最后一天,用在周表示该月最后一个星期X

                   “W”字符:指定离给定日期最近的工作日(周一到周五)

                   “#”字符:表示该月第几个周X。6#3表示该月第3个周五

             2)Cron表达式范例:

                     每隔5秒执行一次:*/5 * * * * ?

                     每隔1分钟执行一次:0 */1 * * * ?

                     每天23点执行一次:0 0 23 * * ?

                     每天凌晨1点执行一次:0 0 1 * * ?

                     每月1号凌晨1点执行一次:0 0 1 1 * ?

                     每月最后一天23点执行一次:0 0 23 L * ?

                     每周星期天凌晨1点实行一次:0 0 1 ? * L

                     在26分、29分、33分执行一次:0 26,29,33 * * * ?

                     每天的0点、13点、18点、21点都执行一次:0 0 0,13,18,21 * * ?

    "0 0 12 * * ?" 每天中午12点触发

    "0 15 10 ? * *" 每天上午10:15触发

    "0 15 10 * * ?" 每天上午10:15触发

    "0 15 10 * * ? *" 每天上午10:15触发

    "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触发

    每天早上6点

    0 6 * * *

    每两个小时

    0 */2 * * *

    晚上11点到早上8点之间每两个小时,早上八点

    0 23-7/2,8 * * *

    每个月的4号和每个礼拜的礼拜一到礼拜三的早上11点

    0 11 4 * 1-3

    1月1日早上4点

    0 4 1 1 *

  • 相关阅读:
    OpenOffice 在 Linux 下安装使用
    LINUX环境使用rpm命令安装gcc
    用shell脚本执行mysql脚本
    CentOS 7下用firewall-cmd控制端口与端口转发详解(转载)
    Hive字段中文注释乱码解决办法
    真正从零开始,TensorFlow详细安装入门图文教程!
    九、Oracle SQL(优化专题&分表分区)
    八、Oracle SQL(聚合函数&标量函数)
    七、Oracle SQL(Oracle 定时任务基础)
    六、Oracle SQL(游标&RECORD&存过、游标、RECORD整合)
  • 原文地址:https://www.cnblogs.com/huhuixin/p/6409386.html
Copyright © 2011-2022 走看看