quartz定时任务时间设置描述
- 格式:docx
- 大小:17.16 KB
- 文档页数:2
C#定时任务的简单使⽤最近做了⼀个定时执⾏任务的软件。
执⾏任务时,会使⽤log4net记录⽇志,如果执⾏任务有异常,则发送邮件给指定的对象。
我做的是每天的9点和16点执⾏⼀次任务,以此记录:⾸先,获得,其实可以使⽤vs2015的Nuget管理器,下载。
我做了⼀个QuartzHelper,但是在主程序中,还是需要其他代码的。
这是QuartzHelper的代码:1using Quartz;2using Quartz.Impl;34namespace Cong.Utility5 {6public class QuartzHelper7 {8///<summary>9///时间间隔执⾏任务10///</summary>11///<typeparam name="T">任务类,必须实现IJob接⼝</typeparam>12///<param name="seconds">时间间隔(单位:毫秒)</param>13public static void ExecuteInterval<T>(int seconds) where T : IJob14 {15 ISchedulerFactory factory = new StdSchedulerFactory();16 IScheduler scheduler = factory.GetScheduler();1718//IJobDetail job = JobBuilder.Create<T>().WithIdentity("job1", "group1").Build();19 IJobDetail job = JobBuilder.Create<T>().Build();2021 ITrigger trigger = TriggerBuilder.Create()22 .StartNow()23 .WithSimpleSchedule(x => x.WithIntervalInSeconds(seconds).RepeatForever())24 .Build();2526 scheduler.ScheduleJob(job, trigger);2728 scheduler.Start();29 }3031///<summary>32///指定时间执⾏任务33///</summary>34///<typeparam name="T">任务类,必须实现IJob接⼝</typeparam>35///<param name="cronExpression">cron表达式,即指定时间点的表达式</param>36public static void ExecuteByCron<T>(string cronExpression) where T : IJob37 {38 ISchedulerFactory factory = new StdSchedulerFactory();39 IScheduler scheduler = factory.GetScheduler();4041 IJobDetail job = JobBuilder.Create<T>().Build();4243//DateTimeOffset startTime = DateBuilder.NextGivenSecondDate(DateTime.Now.AddSeconds(1), 2);44//DateTimeOffset endTime = DateBuilder.NextGivenSecondDate(DateTime.Now.AddYears(2), 3);4546 ICronTrigger trigger = (ICronTrigger)TriggerBuilder.Create()47//.StartAt(startTime).EndAt(endTime)48 .WithCronSchedule(cronExpression)49 .Build();5051 scheduler.ScheduleJob(job, trigger);5253 scheduler.Start();5455//Thread.Sleep(TimeSpan.FromDays(2));56//scheduler.Shutdown();57 }58 }5960#region任务执⾏例61//public class MyJob : IJob62//{63// public void Execute(IJobExecutionContext context)64// {65// Console.WriteLine("executed..." + DateTime.Now.ToString("yyyy/MM/dd HH:mm:ss"));66// }67//}68#endregion69 }⼤概的过程是这样的:通过ISchedulerFactory实例化⼀个计划⼯⼚对象,并使⽤⼯⼚实例化⼀个scheduler计划对象,然后实例化⼀个任务对象job,也就是定义任务内容的对象,需要传⼊⼀个实现IJob接⼝的类,这⾥我使⽤了泛型,接着,需要⼀个能触发任务的对象,这⾥有两种,⼀种是ITrigger,这是⽤于规格时间间隔,计划开始后,会根据间隔的时间值,触发执⾏任务;另⼀种是ICronTrigger,这是通过Cron表达式规格执⾏的时间,计划开始后,如果时间符合规定时间,就触发执⾏任务。
1. 什么是quartzmanager表达式quartzmanager表达式是用来定义quartz调度器中任务调度的时间规则的一种表达式。
它由7个部分组成,分别表示秒、分、时、日期、月份、星期和年。
2. quartzmanager表达式的语法quartzmanager表达式的语法非常简单,在每个部分中用空格或者逗号隔开不同的时间点或者时间范围,用“*”表示任意时间,用“?”表示不指定。
比如:- “0 0 12 * * ?”表示每天12点触发任务- “0 15 10 ? * MON-FRI”表示周一至周五每天10点15分触发任务- “0 0 12 * 3#2 ?”表示每个月第二个星期三12点触发任务3. quartzmanager表达式的应用场景quartzmanager表达式广泛应用于各种定时任务的调度,比如定时发送邮件、定时执行数据同步、定时生成报表等。
它灵活、强大,可以满足各种复杂的调度需求。
4. quartzmanager表达式的高级用法quartzmanager表达式还支持一些高级的用法,比如:- “L”表示最后一天,比如“0 0 12 L * ?”表示每个月最后一天12点触发任务- “W”表示工作日,比如“0 15 10 * * ?”表示每个月最后一个工作日10点15分触发任务- “#”表示第几个星期几,比如“0 0 12 * 3#2 ?”表示每个月第二个星期三12点触发任务5. quartzmanager表达式的注意事项在使用quartzmanager表达式时需要注意以下几点:- quartzmanager表达式不支持年份以前的时间点- quartzmanager表达式的最小时间单位为秒- quartzmanager表达式的日期和星期两个部分不能同时为“*”- quartzmanager表达式的时间范围不能跨月或者年- quartzmanager表达式不支持无限重复执行6. 总结quartzmanager表达式作为quartz调度器中任务调度的时间规则,是实现定时任务调度的核心。
⽤Quartz处理定时执⾏的任务这次做的项⽬中,有⼀部分功能需要实现定时执⾏。
呃,这样说可能有点笼统,打个⽐⽅吧。
例如⽤户在登录的时候,连续输错3次密码后,系统会将该⽤户冻结,不再允许该⽤户登录系统,等到了晚上零晨时分,再为所有被冻结的⽤户解冻,这样,⽤户在第⼆天⼜可以正常登录系统了。
这样做是为了⽤户帐号安全,可有效防⽌暴⼒破解密码。
呃,好像跑题了,咱还是回到正题来。
在这⾥我们只关⼼怎么能实现每天晚上零晨准时执⾏为⽤户解冻的程序。
第⼀时间,我想到了JDK⾃带的Timer和TimerTask类,可经过测试,要想做到精准的定时,还是⽐较困难的。
于是另寻其它解决⽅案,就找到了Quartz,⾄于Quartz是什么,我想百度会告诉⼤家的。
⼆话不说,下载了Quartz包,下载的是官⽅最新版2.1.7。
然后兴致勃勃的百度起来,关于Quartz的⽤法,⽂章还是挺多的,但是,Copy进来后,总是报错。
⽆奈,最新版的⽤法,⽹上⼜很难找到。
怎么办呢?⾃⼰E⽂⼜不好!哎,E⽂是我永远的痛啊,谁叫俺爱国呢。
翻了⼀下下载的Quartz包,发现⾥⾯有好多例⼦,然后挨个挨个跑例⼦。
哈,功夫不负有⼼⼈啊,第三个例⼦刚好能解决我现在的问题,再仔细推敲⼀下,发现Quartz原来如此好⽤。
为了⽅便⽇后重复利⽤,也为了其他没⽤过Quartz⽽且E⽂也不怎么好的朋友不再受折磨,就决定把这次的使⽤⼼德记录下来。
第⼀步:引包 要使⽤Quartz,必须要引⼊以下这⼏个包: 1、log4j-1.2.16 2、quartz-2.1.7 3、slf4j-api-1.6.1.jar 4、slf4j-log4j12-1.6.1.jar 这些包都在下载的Quartz包⾥⾯包含着,因此没有必要为寻找这⼏个包⽽头疼。
第⼆步:创建要被定执⾏的任务类 这⼀步也很简单,只需要创建⼀个实现了org.quartz.Job接⼝的类,并实现这个接⼝的唯⼀⼀个⽅法execute(JobExecutionContext arg0) throws JobExecutionException即可。
quartz的cron表达式Quartz的Cron表达式简介1. 什么是Cron表达式Cron表达式是一种用于定时任务调度的标准格式。
在Quartz框架中,Cron表达式被广泛使用,用于设置任务的执行时间。
2. Cron表达式的语法Cron表达式由6个或7个字段组成,每个字段代表时间的一个维度。
这6个或7个字段分别是:•秒(0~59)•分钟(0~59)•小时(0~23)•日(1~31)•月(1~12)•周几(0~7,0和7都代表周日)可以使用通配符或范围来表示时间的不确定性。
例如,“*“代表所有可能的值,”?“在日和周几字段中代表不指定值,”-“用来表示范围,” / “用来表示递增间隔。
例如,要设置每天早上9点执行任务,Cron表达式可以是0 0 9 ? * *。
3. 常用的Cron表达式示例以下是一些常见的Cron表达式示例:•0 0/5 * * * ?表示每隔5分钟执行一次任务。
•0 0 12 * * ?表示每天中午12点执行任务。
•0 0 8 ? * MON-FRI表示周一到周五每天早上8点执行任务。
•0 0 8 ? * 6L表示每个月的最后一个周五早上8点执行任务。
4. Cron表达式的高级用法Cron表达式还支持一些高级功能,例如使用”#“指定月份中的第几个周几,使用”L”指定月份中的最后一天,使用”W”指定平日最近的工作日等等。
以下是一些高级用法的示例:•0 0 12 ? JAN,FEB,DEC *表示一月、二月和十二月每天中午12点执行任务。
•0 0/30 9-17 * * MON-FRI#2表示周一到周五上午9点到下午5点之间,每隔30分钟执行一次任务,并且每个月的第二个周一符合条件。
5. 总结Cron表达式是Quartz框架中用于指定任务执行时间的标准格式。
它非常灵活,并且支持多种时间维度的设置。
掌握Cron表达式的语法和常用示例,可以帮助我们轻松实现定时任务的调度。
6. Cron表达式的注意事项在使用Cron表达式时,需要注意以下几点:•时间表达式字段之间使用空格分隔。
org.springframework.scheduling.quartz.CronTriggerBean允许你更精确地控制任务的运行时间,只需要设置其cronExpression属性。
一个cronExpression表达式有至少6个(也可能是7个)由空格分隔的时间元素。
从左至右,这些元素的定义如下:1.秒(0–59)2.分钟(0–59)3.小时(0–23)4.月份中的日期(1–31)5.月份(1–12或JAN–DEC)6.星期中的日期(1–7或SUN–SAT)7.年份(1970–2099)0 0 10,14,16 * * ? 每天上午10点,下午2点和下午4点0 0,15,30,45 * 1-10 * ? 每月前10天每隔15分钟30 0 0 1 1 ? 2012 在2012年1月1日午夜过30秒时0 0 8-5 ? * MON-FRI 每个工作日的工作时间各个时间可用值如下:秒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秒‖。
SpringBoot中使⽤Quartz管理定时任务的⽅法定时任务在系统中⽤到的地⽅很多,例如每晚凌晨的数据备份,每⼩时获取第三⽅平台的 Token 信息等等,之前我们都是在项⽬中规定这个定时任务什么时候启动,到时间了便会⾃⼰启动,那么我们想要停⽌这个定时任务的时候,就需要去改动代码,还得启停服务器,这是⾮常不友好的事情直⾄遇见 Quartz,利⽤图形界⾯可视化管理定时任务,使得我们对定时任务的管理更加⽅便,快捷⼀、Quartz 简介Quartz是⼀个开源的作业调度框架,它完全由Java写成,并设计⽤于J2SE和J2EE应⽤中。
它提供了巨⼤的灵活性⽽不牺牲简单性。
你能够⽤它来为执⾏⼀个作业⽽创建简单的或复杂的调度。
它有很多特征,如:数据库⽀持,集群,插件,EJB作业预构建,JavaMail及其它,⽀持cron-like表达式等等。
⼆、开发前戏1、引⼊ maven 依赖<!-- web⽀持 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!-- Quartz 定时任务 --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-quartz</artifactId></dependency>这⾥引⼊了 web 的依赖,以及 Quartz 的依赖,其余依赖请根据需求⾃⾏引⼊2、创建数据表数据模型:SQL语句:drop table if exists sys_quartz;/*==============================================================*//* Table: sys_quartz *//*==============================================================*/create table sys_quartz(id bigint(20) not null auto_increment comment '主键id',class_name varchar(32) comment '任务类名',cron_expression varchar(32) comment 'cron表达式',param varchar(32) comment '参数',descript varchar(11) comment '描述',quartz_status varchar(255) comment '启动状态(0--启动1--停⽌)',create_time datetime comment '创建时间',create_user bigint(20) comment '创建⼈',status tinyint(1) default 0 comment '状态(0--正常1--停⽤)',del_flag tinyint(1) default 0 comment '删除状态(0,正常,1已删除)',primary key (id))type = InnoDB;alter table sys_quartz comment '定时任务信息表';三、开发进⾏中1、创建实体类import com.baomidou.mybatisplus.annotation.*;import com.baomidou.mybatisplus.extension.activerecord.Model;import mon.annotation.Dict;import io.swagger.annotations.ApiModel;import io.swagger.annotations.ApiModelProperty;import lombok.Data;import lombok.EqualsAndHashCode;import lombok.experimental.Accessors;import java.io.Serializable;/*** <p>* 定时任务信息表* </p>** @author lizhou* @since 2020-07-21*/@Data@EqualsAndHashCode(callSuper = false)@Accessors(chain = true)@TableName("sys_quartz")@ApiModel(value="SysQuartz对象", description="定时任务信息表")public class SysQuartz extends Model<SysQuartz> {@ApiModelProperty(value = "主键id")@TableId(value = "id", type = IdType.AUTO)private Long id;@ApiModelProperty(value = "任务类名")@TableField("class_name")private String className;@ApiModelProperty(value = "cron表达式")@TableField("cron_expression")private String cronExpression;@ApiModelProperty(value = "参数")@TableField("param")private String param;@ApiModelProperty(value = "描述")@TableField("descript")private String descript;@ApiModelProperty(value = "启动状态(0--启动1--停⽌)")@TableField("quartz_status")private Integer quartzStatus;@ApiModelProperty(value = "状态(0--正常1--停⽤)")@TableField("status")private Integer status;@ApiModelProperty(value = "删除状态(0--未删除1--已删除)")@TableField("del_flag")@TableLogicprivate Integer delFlag;@ApiModelProperty(value = "创建者")@TableField("create_user")private Long createUser;@ApiModelProperty(value = "创建时间")@TableField("create_time")private String createTime;@Overrideprotected Serializable pkVal() {return this.id;}}2、实现定时任务的 CRUD下⾯我们就要完成定时任务的新增、修改、删除、启停等基本操作了,由于不是很复杂,这⾥的代码就不贴出来了,贴⼏张图吧列表页:新增页:四、定时任务1、定时任务类我们把定时任务都放在 job 包下⾯,⼀个定时任务就是⼀个⽂件,写⼀个测试的类 TestJob.javaimport mon.utils.DateUtils;import lombok.extern.slf4j.Slf4j;import org.quartz.Job;import org.quartz.JobExecutionContext;import org.quartz.JobExecutionException;/*** @ClassName TestJob* 测试定时任务* @Author Lizhou* @Date 2020-07-21 10:58:58**/@Slf4jpublic class TestJob implements Job {@Overridepublic void execute(JobExecutionContext jobExecutionContext) throws JobExecutionException {System.out.println("定时任务启动:" + DateUtils.getYmdHms());}}TestJob 这个类实现了 Job 接⼝,实现了 execute ⽅法,这⾥还可以接收参数这个⽂件在 com.zyxx.sbm.job 包下⾯,那么在页⾯新增定时任务的时候,就需要填写任务类名为:com.zyxx.sbm.job.TestJob cron 表达式的知识这⾥就不⼀⼀介绍了2、页⾯添加定时任务那么我们的任务类名就是:com.zyxx.sbm.job.TestJobcron 表达式:*/2 * * * * ?,表⽰两秒钟执⾏⼀次参数:我们没有传⼊参数3、后台添加定时任务package com.zyxx.sbm.service.impl;import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;import com.baomidou.mybatisplus.core.metadata.IPage;import com.baomidou.mybatisplus.extension.plugins.pagination.Page;import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;import mon.shiro.SingletonLoginUtils;import mon.utils.DateUtils;import yTableResult;import mon.utils.ResponseResult;import com.zyxx.sbm.entity.SysQuartz;import com.zyxx.sbm.mapper.SysQuartzMapper;import com.zyxx.sbm.service.SysQuartzService;import lombok.extern.slf4j.Slf4j;import ng3.StringUtils;import org.quartz.*;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Service;import java.util.List;/*** <p>* 定时任务信息表服务实现类* </p>** @author lizhou* @since 2020-07-21*/@Slf4j@Servicepublic class SysQuartzServiceImpl extends ServiceImpl<SysQuartzMapper, SysQuartz> implements SysQuartzService {@Autowiredprivate Scheduler scheduler;/*** 添加定时任务*/@Overridepublic ResponseResult add(SysQuartz sysQuartz) {QueryWrapper<SysQuartz> queryWrapper = new QueryWrapper<>();queryWrapper.eq("class_name", sysQuartz.getClassName());List<SysQuartz> sysQuartzList = list(queryWrapper);if (null != sysQuartzList && !sysQuartzList.isEmpty()) {return ResponseResult.getInstance().error("该任务类名已经存在");}sysQuartz.setCreateTime(DateUtils.getYmdHms());sysQuartz.setCreateUser(SingletonLoginUtils.getUserId());save(sysQuartz);// 启动if (0 == sysQuartz.getQuartzStatus()) {this.schedulerAdd(sysQuartz.getClassName().trim(), sysQuartz.getCronExpression().trim(), sysQuartz.getParam());}return ResponseResult.getInstance().success();}/*** 添加定时任务** @param className* @param cronExpression* @param param*/@Overridepublic void schedulerAdd(String className, String cronExpression, String param) {try {// 启动调度器scheduler.start();// 构建job信息JobDetail jobDetail = JobBuilder.newJob(getClass(className).getClass()).withIdentity(className).usingJobData("param", param).build(); // 表达式调度构建器(即任务执⾏的时间)CronScheduleBuilder scheduleBuilder = CronScheduleBuilder.cronSchedule(cronExpression);// 按新的cronExpression表达式构建⼀个新的triggerCronTrigger trigger = TriggerBuilder.newTrigger().withIdentity(className).withSchedule(scheduleBuilder).build();scheduler.scheduleJob(jobDetail, trigger);} catch (SchedulerException e) {log.error(e.getMessage());} catch (RuntimeException e) {log.error(e.getMessage());} catch (Exception e) {log.error(e.getMessage());}}/*** 删除定时任务** @param className*/@Overridepublic void schedulerDelete(String className) {try {scheduler.pauseTrigger(TriggerKey.triggerKey(className));scheduler.unscheduleJob(TriggerKey.triggerKey(className));scheduler.deleteJob(JobKey.jobKey(className));} catch (Exception e) {log.error(e.getMessage(), e);}}private static Job getClass(String className) throws Exception {Class<?> class1 = Class.forName(className);return (Job) class1.newInstance();}}需要注⼊ Scheduler 对象,使⽤该对象开启或停⽌定时任务在启动定时任务之前,我们应先删除该任务类名开启的定时任务,防⽌该任务类名已经添加过了// 删除定时任务schedulerDelete(sysQuartz.getClassName().trim());// 添加定时任务schedulerAdd(sysQuartz.getClassName().trim(), sysQuartz.getCronExpression().trim(), sysQuartz.getParam());添加定时任务,传⼊任务类名,cron 表达式,参数停⽌定时任务,只需要:scheduler.pauseJob(JobKey.jobKey(sysQuartz.getClassName().trim()));根据任务类名,停⽌定时任务即可五、开发测试启动项⽬,在管理界⾯,开启定时任务,即可在控制台看到打印的信息表⽰我们的定时任务已经启动成功了六、优化建议当我们添加了定时任务并启动后,重新启动项⽬的时候,定时任务却不会⾃动启动,这时候,我们就需要在项⽬启动的时候做⼀些事情了,也就是系统启动任务不清楚的同学可以复习⼀下之前我的博客【SpringBoot】⼗九、SpringBoot中实现启动任务import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;import com.zyxx.sbm.entity.SysQuartz;import com.zyxx.sbm.service.SysQuartzService;import org.springframework.beans.factory.annotation.Autowired;import mandLineRunner;import org.springframework.core.annotation.Order;import ponent;import java.util.List;/*** @ClassName SystemStartTask* 项⽬启动任务--启动定时任务* @Author Lizhou* @Date 2020-07-21 12:56:56**/@Component@Order(100)public class SystemQuartzStartTask implements CommandLineRunner {@Autowiredprivate SysQuartzService sysQuartzService;@Overridepublic void run(String... args) throws Exception {// 查询启动的定时任务QueryWrapper<SysQuartz> queryWrapper = new QueryWrapper<>();queryWrapper.eq("status", 0);queryWrapper.eq("quartz_status", 0);List<SysQuartz> list = sysQuartzService.list(queryWrapper);if (null != list && !list.isEmpty()) {for (SysQuartz item : list) {// 删除定时任务sysQuartzService.schedulerDelete(item.getClassName().trim());// 添加定时任务sysQuartzService.schedulerAdd(item.getClassName().trim(), item.getCronExpression().trim(), item.getParam());}}}}从数据库查询出启动的定时任务,并将他们添加到定时任务启动中,这样项⽬⼀启动时,就会⾃动启动我们定义的定时任务了最后任务类名的正则表达式/^[a-zA-Z]+(\.([a-zA-Z])+)+$/cron 表达式的验证使⽤正则太⿇烦,可以使⽤ Quartz ⾃带验证⽅法CronExpression.isValidExpression(cron)SpringBoot 中使⽤ Quartz 管理定时任务的学习就到这⼉了,其实也并不难理解,相⽐于之前⽤的定时任务是不是好很多了呢,别忘了最后加上系统启动任务哦总结到此这篇关于SpringBoot中使⽤Quartz管理定时任务的⽂章就介绍到这了,更多相关SpringBoot管理定时任务内容请搜索以前的⽂章或继续浏览下⾯的相关⽂章希望⼤家以后多多⽀持!。
Quartz中时间表达式的设置-----corn表达式时间格式: <!-- s m h d m w(?) y(?) -->, 分别对应: 秒>分>小时>日>月>周>年, 举例:1.每天什么时候执行:<value>0 59 23 * * ?</value>: 如下为每天23:59:00开始执行<value>0 1,2,3 11,12 * * ? </value>: 每天11:01,11:02,11:03;12:01,12:02,12:03分执行任务2.每隔多久执行:汇总说明:Cron表达式的时间字段除允许设置数值外,还可使用一些特殊的字符,提供列表、范围、通配符等功能,细说如下:●星号(*):可用在所有字段中,表示对应时间域的每一个时刻,例如,*在分钟字段时,表示“每分钟”;●问号(?):该字符只在日期和星期字段中使用,它通常指定为“无意义的值”,相当于点位符;●减号(-):表达一个范围,如在小时字段中使用“10-12”,则表示从10到12点,即10,11,12;●逗号(,):表达一个列表值,如在星期字段中使用“MON,WED,FRI”,则表示星期一,星期三和星期五;●斜杠(/):x/y表达一个等步长序列,x为起始值,y为增量步长值。
如在分钟字段中使用0/15,则表示为0,15,30和45秒,而5/15在分钟字段中表示5,20,35,50,你也可以使用*/y,它等同于0/y;==================================================Quartz cron 表达式的格式十分类似于UNIX cron 格式,但还是有少许明显的区别。
区别之一就是Quartz 的格式向下支持到秒级别的计划,而UNIX cron 计划仅支持至分钟级。
许多我们的触发计划要基于秒级递增的(例如,每45秒),因此这是一个非常好的差异。
Spring+Quartz实现定时任务的配置方法第一步:.导入相关的jar包(1)spring.jar(2)quartz-1.6.0.jar(3)相关包commons-collections-3.2.jar ; commons-logging-1.1.1.jar; log4j-1.2.16.jar第二步:创建一个类来定义工作定义Quartz工作的第一步是创建一个类来定义工作。
要做到这一点,你需要从Spring 的QuartzJobBean中派生子类。
第三步:配置JobDetail值得注意的是,在这里你并没有直接声明一个TopTenTask Bean,而是声明了一个JobDetailBean。
这是使用Quartz时的一个特点。
JobDetailBean是Quartz的org.quartz.JobDetail的子类,它要求通过jobClass属性来设置一个Job对象。
使用Quartz的JobDetail中的另一个特别之处是TopTenTask的timeout属性是间接设置的。
JobDetail的jobDataAsMap属性接受一个java.util.Map,其中包含了需要设置给jobClass的各种属性。
在这里,这个map包含了一个键值为timeout。
当JobDetailBean实例化时,它会将5注入到EmailReportJob的timeout属性中。
第四步:配置Trigger工作已经被定义好了,接下来你需要调度这个工作。
Quartz的org.quartz.Trigger类描述了何时及以怎样的频度运行一个Quartz工作。
Spring提供了两个触发器,SimpleTriggerBean和CronTriggerBean。
SimpleTriggerBean与ScheduledTimerTask类似。
你可以用它来指定一个工作应该以怎样的频度运行,以及(可选地)在第一次运行工作之前应该等待多久。
例如,要调度报表工作每24小时运行一次,第一次在1小时之后开始运行,可以按照以下方式进行声明:<bean id="topTenTrigger"class="org.springframework.scheduling.quartz.SimpleTriggerBean"><property name="jobDetail"><ref bean="topTenTask"/></property><property name="startDelay"><value>3600000</value></property><property name="repeatInterval"><value>86400000</value></property></bean>属性jobDetail装配了将要被调度的工作,在这个例子中是topTenTask Bean。
quartz配置规则Quartz配置规则Quartz是一个广泛使用的开源作业调度框架,它允许开发人员可以自动执行预定的任务。
Quartz主要用于在特定的时间触发作业,并且支持高度可配置的调度规则。
本文将介绍Quartz的配置规则,以及如何一步一步地进行配置。
1. 引入Quartz依赖首先,我们需要在项目中引入Quartz的依赖。
这可以通过在项目的构建文件中添加相应的依赖来实现。
例如,如果我们使用Maven进行项目构建,可以在pom.xml文件中添加以下依赖:<dependency><groupId>org.quartz-scheduler</groupId><artifactId>quartz</artifactId><version>2.3.2</version></dependency>2. 创建Quartz配置文件接下来,我们需要创建一个Quartz的配置文件,用于定义作业调度的规则。
该配置文件通常命名为quartz.properties,并且需要将其放置在项目的classpath 下。
以下是一个简单的quartz.properties示例:org.quartz.scheduler.instanceName = MySchedulerorg.quartz.scheduler.instanceId = AUTOorg.quartz.threadPool.threadCount = 10org.quartz.plugin.triggerHistoryPlugin.class =org.quartz.plugins.history.LoggingTriggerHistoryPluginorg.quartz.plugin.triggerHistoryPlugin.triggerFiredMessage = Trigger {1}.{0} fired job {6}.{5} at: {4, date, HH:mm:ss MM/dd/yyyy}org.quartz.plugin.triggerHistoryPlugin.triggerCompleteMessage = Trigger {1}.{0} completed firing job {6}.{5} at {4, date, HH:mm:ssMM/dd/yyyy}org.quartz.plugin.jobHistoryPlugin.class =org.quartz.plugins.history.LoggingJobHistoryPluginorg.quartz.plugin.jobHistoryPlugin.jobT oBeFiredMessage = Job {1}.{0} is about to be executed.org.quartz.plugin.jobHistoryPlugin.jobSuccessMessage = Job {1}.{0} bisexecuted successfully.org.quartz.plugin.jobHistoryPlugin.jobFailedMessage = Job {1}.{0} has failed to execute successfully.在这个示例中,我们定义了Quartz调度器的实例名称(MyScheduler),线程池的大小(10),以及作业历史插件的配置。
quartz表达式Quartz表达式是Quartz作业调度库中一个功能强大的子模块,它能够按照用户所设定的时间表运行Java应用程序。
本文将介绍Quartz表达式的语法,解释如何使用它来设计复杂的定时任务,以及如何实现一个简单的Quartz调度程序。
Quartz表达式的语法是用来描述一个定时调度任务的时间表。
它支持一个或多个任务执行的时间表定义,如何组织任务,以及任务执行的时间段。
它的语法模式如下:<second>(s|S) <minute>(m|M) <hour>(h|H)<day-of-the-month>(d|D) <month>(M|m) <day-of-the-week>(E|e) <year>(Y|y)?其中,每个括号中的字符代表一个概念,即要按照Quartz表达式运行任务,你必须指定每秒、每分钟和每小时执行任务,以及每月和每年的哪一天运行任务。
比如,如果你想每天的8点和18点运行任务,可以使用Quartz 表达式“0 0 8,18 * *”来描述任务时间表,即“每秒的0秒,每分钟的0分,每小时的8和18点,每月的任意一天,任意一个星期几”。
另外,Quartz表达式还允许你设置更复杂的定时任务。
比如,你可以设置定期重复运行任务,如每隔5分钟执行一次,可以使用Quartz表达式“*/5 * * * *”来描述这种任务时间表,即“所有秒,每分钟的每5分钟,每小时的任意时刻,每月的任意一天,任意一个星期几”。
此外,你还可以在Quartz表达式中指定一个更具体的时间段,比如每月的15号到20号,每个星期的周一到周五,每小时的10分到11分,等等。
下面介绍如何使用Quartz表达式实现一个简单的Quartz作业调度程序。
首先,定义一个Quartz表达式,比如上文中提到的“ */5 * * * *”,它每隔5分钟执行一次任务。
quartz定时任务时间设置描述
这些星号由左到右按顺序代表:* * * * * * *
格式: [秒] [分] [小时] [日] [月] [周] [年]
通配符说明:
* 表示所有值. 例如:在分的字段上设置"*",表示每一分钟都会触发。
? 表示不指定值。
使用的场景为不需要关心当前设置这个字段的值。
例如:要在每月的10号触发一个操作,但不关心是周几,所以需要周位置的那个字段设置为"?" 具体设置为0 0 0 10 * ?
- 表示区间。
例如在小时上设置"10-12",表示10,11,12点都会触发。
, 表示指定多个值,例如在周字段上设置"MON,WED,FRI" 表示周一,周三和周五触发
/ 用于递增触发。
如在秒上面设置"5/15" 表示从5秒开始,每增15秒触发(5,20,35,50)。
在月字段上设置'1/3'所示每月1号开始,每隔三天触发一次。
L 表示最后的意思。
在日字段设置上,表示当月的最后一天(依据当前月份,如果是二月还会依据是否是润年[leap]), 在周字段上表示星期六,相当于"7"或"SAT"。
如果在"L"前加上数字,则表示该数据的最后一个。
例如在周字段上设置"6L"这样的格式,则表示“本月最后一个星期五"
W 表示离指定日期的最近那个工作日(周一至周五). 例如在日字段上设置"15W",表示离每月15号最近的那个工作日触发。
如果15号正好是周六,则找最近的周五(14号)触发, 如果15号是周未,则找最近的下周一(16号)触发.如果15号正好在工作日(周一至周五),则就在该天触发。
如果指定格式为"1W",它则表示每月1号往后最近的工作日触发。
如果1号正是周六,则将在3号下周一触发。
(注,"W"前只能设置具体的数字,不允许区间"-").
小提示
'L'和'W'可以一组合使用。
如果在日字段上设置"LW",则表示在本月的最后一个工作日触发(一般指发工资)
# 序号(表示每月的第几个周几),例如在周字段上设置"6#3"表示在每月的第三个周六.注意如果指定"#5",正好第五周没有周六,则不会触发该配置(用在母亲节和父亲节再合适不过了)
小提示
周字段的设置,若使用英文字母是不区分大小写的MON 与mon相同.
常用示例:
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分每分触发
0 0/5 14 * * ? 每天下午的2点到2点59分(整点开始,每隔5分触发)
0 0/5 14,18 * * ? 每天下午的2点到2点59分(整点开始,每隔5分触发)
每天下午的18点到18点59分(整点开始,每隔5分触发)
0 0-5 14 * * ? 每天下午的2点到2点05分每分触发
0 10,44 14 ? 3 WED 3月分每周三下午的2点10分和2点44分触发(特殊情况,在一个时间设置里,执行两次或两次以上的情况)
0 59 2 ? * FRI 每周5凌晨2点59分触发;
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 每月的第三周的星期五开始触发
0 0 12 1/5 * ? 每月的第一个中午开始每隔5天触发一次
0 11 11 11 11 ? 每年的11月11号11点11分触发(光棍节)。