quartz详解3-Trigger

1. Trigger

trigger通过TriggerBuilder实现。(注意Builder的链式)

Trigger对象用来告诉调度程序作业什么时候触发。
即触发执行job。

Trigger触发器:执行任务的规则;比如每天,每小时等。
一般情况使用SimpleTrigger,和CronTrigger,这个触发器实现了Trigger接口。

1.对于复杂的时间表达式来说,比如每个月15日上午几点几分,使用CronTrigger
2.对于简单的时间来说,比如每天执行几次,使用SimpleTrigger

/ 1 / 触发器通用属性

1.JobKey
2.StartTime
3.EndTime

  • JobKey 触发器触发时,该指定的Job实例运行
  • StartTime 触发器首次首发时间(java.util.Date
  • EndTime 不再被触发的时间(java.util.Date

Scheduler中的部分业务

/*
Scheduler
3s开始执行,6s结束。每隔2s执行一次
相当于3s,5s在执行。然后停止
*/
//2.定义Trigger实例,定义该job立即执行,并且每隔两秒重复执行一次,直到永远
        Date d = new Date();
        Trigger trigger = TriggerBuilder
                .newTrigger()
                .withIdentity("mytrigger","group1")
                .usingJobData("message","hello mytrigger1")
                .usingJobData("DoubleTriggerValue",5.21D)
                .startAt(new Date(d.getTime()+3000)) //(1)开始执行
                .endAt(new Date(d.getTime()+6000))   //(2)结束执行
                .withSchedule(
                        SimpleScheduleBuilder
                                .simpleSchedule()
                                .withIntervalInSeconds(2)
                                .repeatForever())
                .build();

job中的部分业务

/*
job
*/
//jobKey(name和group)
Trigger t = context.getTrigger();
System.out.println("trigger jonKey"+t.getJobKey().getName());

2. SimpleTrigger

  • 在指定的时间段内执行一次作业任务
  • 在指定的时间间隔内多次执行作业任务

2.1 示例1:4s后执行且只执行1次

直接标明开始时间即可,不给策略就是执行一次

        //2.定义Trigger实例
        Date d = new Date();
        SimpleTrigger trigger = (SimpleTrigger) TriggerBuilder
                .newTrigger()
                .withIdentity("mytrigger","group1")
                .usingJobData("message","hello mytrigger1")
                .usingJobData("DoubleTriggerValue",5.21D)
                .startAt(new Date(d.getTime()+4000))
                .build();

2.2 示例2:有起止时间,间隔执行

见本节1中的代码即是。
或者稍微修改,指定次数为无限即可(给定具体数字可以)。

//2.定义Trigger实例
Date d = new Date();
SimpleTrigger trigger = (SimpleTrigger) TriggerBuilder
        .newTrigger()
        .withIdentity("mytrigger","group1")
        .usingJobData("message","hello mytrigger1")
        .usingJobData("DoubleTriggerValue",5.21D)
        .startAt(new Date(d.getTime()+4000))
        .withSchedule(
                SimpleScheduleBuilder.simpleSchedule()
                .withIntervalInSeconds(2)
                .withRepeatCount(SimpleTrigger.REPEAT_INDEFINITELY)
        )
        .build();

3. CronTrigger

  • 基于日历作业调度器,比SimpleTrigger更常用
 //2(1).定义CronTrigger
   CronTrigger cronTrigger =TriggerBuilder
            .newTrigger()
            .withIdentity("myCronTrigger","group1")
            .withSchedule(
                CronScheduleBuilder.cronSchedule("0/10 * * ? * *")
            )
                .build();

Cron表达式

  • 用于配置CronTrigger实例
  • 7个子表达式组成的字符串,描述了时间表的详细信息。
  • 格式:[秒] [分] [小时] [日] [月] [周] [年]

cron的表达式被用来配置CronTrigger实例。 cron的表达式是字符串,实际上是由七子表达式,描述个别细节的时间表。这些子表达式是分开的空白,代表:

  1. Seconds
  2. Minutes
  3. Hours
  4. Day-of-Month
  5. Month
  6. Day-of-Week
  7. Year (可选字段)

例 “0 0 12 ? * WED” 在每星期三下午12:00 执行,

个别子表达式可以包含范围, 例如,在前面的例子里(“WED”)可以替换成 “MON-FRI”, “MON, WED, FRI”甚至”MON-WED,SAT”.

“*” 代表整个时间段.

每一个字段都有一套可以指定有效值,如
Seconds (秒):可以用数字0-59 表示,
Minutes(分):可以用数字0-59 表示,
Hours(时) :可以用数字0-23表示,
Day-of-Month(天) :可以用数字1-31 中的任一一个值,但要注意一些特别的月份
Month(月) :可以用0-11 或用字符串 “JAN, FEB, MAR, APR, MAY, JUN, JUL, AUG, SEP, OCT, NOV and DEC” 表示
Day-of-Week(每周):可以用数字1-7表示(1 = 星期日)或用字符口串“SUN, MON, TUE, WED, THU, FRI and SAT”表示

“/”:为特别单位,表示为“每”如“0/15”表示每隔15分钟执行一次,“0”表示为从“0”分开始, “3/20”表示表示每隔20分钟执行一次,“3”表示从第3分钟开始执行
“?”:表示每月的某一天,或第周的某一天
“L”:用于每月,或每周,表示为每月的最后一天,或每个月的最后星期几如“6L”表示“每月的最后一个星期五”
“W”:表示为最近工作日,如“15W”放在每月(day-of-month)字段上表示为“到本月15日最近的工作日”
““#”:是用来指定“的”每月第n个工作日,例 在每周(day-of-week)这个字段中内容为”6#3” or “FRI#3” 则表示“每月第三个星期五”

字段名允许的值允许的特殊字符
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个周五

Cron表达式范例:
每隔5秒执行一次:*/5 * * * * ?
每隔1分钟执行一次:0 */1 * * * ?
每天23点执行一次:0 0 23 * * ?
每天凌晨1点执行一次:0 0 1 * * ?
每月1号凌晨1点执行一次:0 0 1 1 * ?
在26分、29分、33分执行一次:0 26,29,33 * * * ?
每天的0点、13点、18点、21点都执行一次:0 0 0,13,18,21 * * ?

参考文献:

  1. Quartz教程
  2. Cron表达式的详细用法
  3. 搜索在线生成工具。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Quartz中,数据库集群是一种高可用性的解决方案。它允许多个Quartz实例共享同一个数据库,并且能够自动协调任务的执行,从而保证任务的可靠性和稳定性。 但是,在多个Quartz实例同时操作同一个数据库时,必须确保它们之间的数据一致性。这就需要使用锁机制来保证数据的正确性和安全性。 Quartz提供了两种类型的锁:悲观锁和乐观锁。它们分别采用不同的方式来保证数据的一致性。 1. 悲观锁 悲观锁是一种悲观的认为并发环境下会出现冲突的锁机制。它在操作数据时,会先加锁,然后再进行操作,操作完成后再释放锁。 在Quartz中,悲观锁是通过数据库中的行级锁来实现的。当一个Quartz实例要对某个任务进行操作时,它会先获取该任务的行级锁,然后再进行操作。其他实例在此期间无法获取该任务的锁,从而保证了数据的一致性。 2. 乐观锁 乐观锁是一种乐观的认为并发环境下不会出现冲突的锁机制。它在操作数据时,不会加锁,而是通过版本号等方式来判断数据是否发生了变化。 在Quartz中,乐观锁是通过版本号来实现的。每个任务都有一个版本号,当一个Quartz实例要对某个任务进行操作时,它会先获取该任务的版本号,然后进行操作。如果在此期间该任务的版本号发生了变化,则说明其他实例已经对该任务进行了操作,当前实例的操作会失败,需要重新获取版本号并重试。这样可以保证数据的一致性。 总的来说,悲观锁适用于高并发、数据冲突严重的场景,但是会带来较大的性能开销;而乐观锁适用于并发量较小、数据冲突不严重的场景,性能开销较小。在Quartz中,可以根据具体的业务需求选择合适的锁机制来保证数据的正确性和安全性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值