Quartz定时任务corn表达式解析

"落花有意随流水,而流水无心恋落花"
Cron表达式被用来配置CronTrigger实例。Cron表达式是一个由 7 个子表达式组成的字
符串。每个子表达式都描述了一个单独的日程细节。这些子表达式用空格分隔,分别表示:
1. Seconds 秒
2. Minutes 分钟
3. Hours 小时
4. Day-of-Month 月中的天
5. Month 月
6. Day-of-Week 周中的天
7. Year (optional field) 年(可选的域)
一个cron表达式的例子字符串为"0 0 12 ? * WED",这表示“每周三的中午 12:00”。
单个子表达式可以包含范围或者列表。例如:前面例子中的周中的天这个域(这里是
"WED")可以被替换为"MON-FRI", "MON, WED, FRI"或者甚至"MON-WED,SAT"。
通配符('*')可以被用来表示域中“每个”可能的值。因此在"Month"域中的*表示
每个月,而在 Day-Of-Week 域中的*则表示“周中的每一天”。
所有的域中的值都有特定的合法范围,这些值的合法范围相当明显,例如:秒和分域
的合法值为 0 到 59,小时的合法范围是 0 到 23,Day-of-Month 中值得合法凡范围是 0
到 31,但是需要注意不同的月份中的天数不同。月份的合法值是 0 到 11。或者用字符串
JAN,FEB MAR, APR, MAY, JUN, JUL, AUG, SEP, OCT, NOV 及 DEC 来表示。
Days-of-Week可以用1到7来表示(1=星期日)或者用字符串SUN, MON, TUE, WED,
THU, FRI 和 SAT 来表示.
'/'字符用来表示值的增量,例如, 如果分钟域中放入'0/15',它表示“每隔 15 分钟,
从 0 开始”,如果在份中域中使用'3/20',则表示“小时中每隔 20 分钟,从第 3 分钟开
始”或者另外相同的形式就是'3,23,43'。
'?'字符可以用在 day-of-month 及 day-of-week 域中,它用来表示“没有指定值”。
这对于需要指定一个或者两个域的值而不需要对其他域进行设置来说相当有用。
'L'字符可以在 day-of-month 及 day-of-week 中使用,这个字符是"last"的简写,
但是在两个域中的意义不同。例如,在 day-of-month 域中的"L"表示这个月的最后一天,
即,一月的 31 日,非闰年的二月的 28 日。如果它用在 day-of-week 中,则表示"7"或
者"SAT"。但是如果在 day-of-week 域中,这个字符跟在别的值后面,则表示"当月的最
后的周 XXX"。例如:"6L" 或者 "FRIL"都表示本月的最后一个周五。当使用'L'选项时,
最重要的是不要指定列表或者值范围,否则会导致混乱。
'W' 字符用来指定距离给定日最接近的周几(在 day-of-week 域中指定)。例如:
如果你为 day-of-month 域指定为"15W",则表示“距离月中 15 号最近的周几”。
'#'表示表示月中的第几个周几。例如:day-of-week 域中的"6#3" 或者 "FRI#3"
表示“月中第三个周五”。
Example Cron Expressions  ——Cron  表达式的例子
CronTrigger 例 1 – 一个简单的每隔 5 分钟触发一次的表达式
"0 0/5 * * * ?"
CronTrigger 例2 – 在每分钟的10秒后每隔5分钟触发一次的表达式(例如. 10:00:10
am, 10:05:10 等.)。
"10 0/5 * * * ?"
CronTrigger 例 3 – 在每个周三和周五的 10:30,11:30,12:30 触发的表达式。
"0 30 10-13 ? * WED,FRI"
CronTrigger 例 4 – 在每个月的 5 号,20 号的 8 点和 10 点之间每隔半个小时触发一次
且不包括 10 点,只是 8:30,9:00 和 9:30 的表达式。
"0 0/30 8-10 5,20 * ?"
注意,对于单独触发器来说,有些日程需求可能过于复杂而不能用表达式表述,例如:
9:00 到 10:00 之间每隔 5 分钟触发一次,下午 1:00 到 10 点每隔 20 分钟触发一次。
这个解决方案就是创建两个触发器,两个触发器都运行相同的任务。
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
cron表达式是用于定义定时任务调度的一种时间表达式。在Vue中,可以使用vue-quartz插件来实现定时任务的调度。 首先,需要在项目中安装vue-quartz插件。可以通过npm或yarn进行安装: ``` npm install vue-quartz ``` 或 ``` yarn add vue-quartz ``` 安装完成后,在Vue的入口文件main.js中引入并注册vue-quartz插件: ```javascript import Vue from 'vue'; import VueQuartz from 'vue-quartz'; Vue.use(VueQuartz); ``` 接下来,在需要定义定时任务的组件中,使用`<cron>`标签来设置cron表达式: ```vue <template> <div> <h1>定时任务</h1> <cron v-model="cronExpression" @change="handleCronChange"></cron> </div> </template> <script> export default { data() { return { cronExpression: '' }; }, methods: { handleCronChange(cronExpression) { // 在这里可以处理cron表达式的变化,并执行相应的操作 console.log('cron表达式变化:', cronExpression); } } }; </script> ``` 在上面的示例中,通过`v-model`指令将cron表达式绑定到组件的data属性`cronExpression`上,并通过`@change`事件监听cron表达式的变化。 当用户在页面上选择或输入cron表达式时,`handleCronChange`方法会被调用,并传入新的cron表达式。在该方法中可以根据cron表达式执行相应的定时任务逻辑。 请注意,以上只是一个简单的示例,具体的定时任务逻辑需要根据实际需求进行实现。同时,需要了解cron表达式的语法规则和含义,以确保正确设置定时任务的执行时间。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值