Spring定时器时间配置(二)

2014-11-24 02:33:28 · 作者: · 浏览: 5
cheduleInfoManager)
    {
        this.scheduleInfoManager = scheduleInfoManager;
    }

    3. Quartz在Spring中动态设置cronTrigger方法二
    在上面的2中我们可以看到,尽管已经可以动态进行rescheduleJob了,不过依然需要我们设置一个cronExpression,如果尝试一下拿掉spring配置中的
    
        0/10 * * * *
    

    则容器(如tomcat)启动时会报错。
    实际中我们希望tomcat启动时就可以直接去读数据库,拿到相应的dbCronExpression,然后定时执行一个job,而不希望配置初始的cronExpression ,观察下面的CronTriggerBean,考虑到cronExpression需要初始化,如果设定一个类InitializingCronTrigger继承CronTriggerBean,然后在这个类中做一些读取DB的初始化工作(设置cronExpression),问题就可以解决了。
    Spring配置文件:
    
        
        
    

    
        
        
        
    

    
        
        
        
    

    
        
            
                
            

        

    

    InitializingCronTrigger中的相关方法
    注意:在注入scheduleInfoManager属性的时候,我们可以去读取DB任务时间(之所以放在setter方法中,是因为需要在设置scheduleInfoManager后进行getCronExpressionFromDB(),否则,也可以①②逻辑把放在类的构造函数中).
    注意InitializingCronTrigger必须extends CronTriggerBean.
    public class InitializingCronTrigger extends CronTriggerBean implements Serializable
    {
        private ScheduleInfoManager scheduleInfoManager;
        // 设值注入,通过setter方法传入被调用者的实例scheduleInfoManager
        public void setScheduleInfoManager(ScheduleInfoManager scheduleInfoManager)
        {
            this.scheduleInfoManager = scheduleInfoManager;
            // 因为在getCronExpressionFromDB使用到了scheduleInfoManager,所以
            // 必须上一行代码设置scheduleInfoManager后进行getCronExpressionFromDB
            String cronExpression = getCronExpressionFromDB (); // ①
            // 因为extends CronTriggerBean ,此处调用父类方法初始化cronExpression
            setCronExpression(cronExpression); // ②
        }

        private String getCronExpressionFromDB()
        {
            String sql="from ScheduleInfo scheduleInfo where 1=1 ";
            sql=sql+" and scheduleInfo.infoId = '"+"1" + "'";
            List scheduleList = scheduleInfoManager.queryScheduleInListBySql(sql);
            ScheduleInfo scheduleInfo = (ScheduleInfo)scheduleList.get(0);
            String dbCronExpression = scheduleInfo.getCronExpression();
            return dbCronExpression;
        }
        ……
    }
各个时间可用值如下:

秒 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 , - * /

可用值详细分析如下:

“*”——字符可以用于所有字段,在“分”字段中设为"*"表示"每一分钟"的含义。

“ ”——字符可以用在“日”和“周几”字段. 它用来指定 '不明确的值'. 这在你需要指定这两个字段中的某一个值而不是另外一个的时候会被用到。在后面的例子中可以看到其含义。

“-”——字符被用来指定一个值的范围,比如在“小时”字段中设为"10-12"表示"10点到12点"。

“,”——字符指定数个值。比如在“周几”字段中设为"MON,WED,FRI"表示"the days Monday, Wednesday, and Friday"。

“/”——字符用来指定一个值的的增加幅度. 比如在“秒”字段中设置为"0/15"表示"第0, 15, 30, 和 45秒"。而 "5/15"则表示"第5, 20, 35, 和 50". 在'/'前加"*"字符相当于指定从0秒开始. 每个字段都有一系列可以开始或结束的数值。对于“秒”和“分”字段来说,其数值范围为0到59,对于“小时”字段来说其为0到23, 对于“日”字段来说为0到31, 而对于“月”字段来说为1到12。"/"字段仅仅只是帮助你在允许的数值范围内从开始"第n"的值。

“L”——字符可用在“日”和“周几”这两个字段。它是"last"的缩写, 但是在这两个字段中有不同的含义。例如,“日”字段中的"L"表示"一个月中的最后一天" —— 对于一月就是31号对于二月来说就是28号(非闰年)。而在“周几”字段中, 它简单的表示"7" or "SAT",但是如果在“周几”字段中使用时跟在某个数字之后, 它表示"该月最后一个星期×" —— 比如"6L"表示"该月最后一个周五"。当使用'L'选项时,指定确定的列表或者范围非常重要,否则你会被结果搞糊涂的。

“W”——可用于“日”字段。用来指定历给定日期最近的工作日(周一到周五) 。比如你将“日”字段设为"15W",意为: "离该月15号最近的工作日"。因此如果15号为周六,触发器会在14号即周五调用。如果15号为周日, 触发器会在16号也就是周一触发。如果15号为周二,那么当天就会触发。然而如果你将“日”字段设为"1W", 而一号又是周六, 触发器会于下周一也就是当月的3号触发,因为它不会越过当月的值的范围边界。'W'字符只能用于“日”字段的值为单独的一天而不是一系列值的时候。

“L”和“W”可以组合用于“日