步骤 2 : 先运行,看到效果,再学习 步骤 3 : 模仿和排错 步骤 4 : TestQuartz 步骤 5 : MailJob 步骤 6 : 分组干什么用? 步骤 7 : 静态导入 步骤 8 : log4j.xml
截至目前(2018-3-23),使用的是 2.2.3 版本
老规矩,先下载右上角的可运行项目,配置运行起来,确认可用之后,再学习做了哪些步骤以达到这样的效果。
运行 TestQuartz ,看到如图所示的效果,每隔2秒钟,总共运行11次
在确保可运行项目能够正确无误地运行之后,再严格照着教程的步骤,对代码模仿一遍。
模仿过程难免代码有出入,导致无法得到期望的运行结果,此时此刻通过比较 正确答案 ( 可运行项目 ) 和自己的代码,来定位问题所在。 采用这种方式, 学习有效果,排错有效率,可以较为明显地提升学习速度,跨过学习路上的各个槛。 推荐使用diffmerge软件,进行文件夹比较。把你自己做的项目文件夹,和我的可运行项目文件夹进行比较。 这个软件很牛逼的,可以知道文件夹里哪两个文件不对,并且很明显地标记出来 这里提供了绿色安装和使用教程: diffmerge 下载和使用教程
几个概念搞清楚先:
触发器 Trigger: 什么时候工作 任务 Job: 做什么工作 调度器 Scheduler: 搭配 Trigger和Job 代码里注释很清楚,直接看注释即可理解
package com.how2java; import static org.quartz.JobBuilder.newJob; import static org.quartz.SimpleScheduleBuilder.simpleSchedule; import static org.quartz.TriggerBuilder.newTrigger; import org.quartz.JobDetail; import org.quartz.Scheduler; import org.quartz.Trigger; import org.quartz.impl.StdSchedulerFactory; public class TestQuartz { public static void main(String[] args) throws Exception{ //创建调度器 Scheduler scheduler = StdSchedulerFactory.getDefaultScheduler(); //定义一个触发器 Trigger trigger = newTrigger().withIdentity("trigger1", "group1") //定义名称和所属的组 .startNow() .withSchedule(simpleSchedule() .withIntervalInSeconds(2) //每隔2秒执行一次 .withRepeatCount(10)) //总共执行11次(第一次执行不基数) .build(); //定义一个JobDetail JobDetail job = newJob(MailJob.class) //指定干活的类MailJob .withIdentity("mailjob1", "mailgroup") //定义任务名称和分组 .usingJobData("email", "[email protected]") //定义属性 .build(); //调度加入这个job scheduler.scheduleJob(job, trigger); //启动 scheduler.start(); //等待20秒,让前面的任务都执行完了之后,再关闭调度器 Thread.sleep(20000); scheduler.shutdown(true); } }
MailJob 实现了 Job 接口,提供 execute,干具体的活儿
package com.how2java; import java.text.SimpleDateFormat; import java.util.Date; import org.quartz.Job; import org.quartz.JobDetail; import org.quartz.JobExecutionContext; import org.quartz.JobExecutionException; public class MailJob implements Job { public void execute(JobExecutionContext context) throws JobExecutionException { JobDetail detail = context.getJobDetail(); String email = detail.getJobDataMap().getString("email"); SimpleDateFormat sdf = new SimpleDateFormat("HH:mm:ss"); String now = sdf.format(new Date()); System.out.printf("给邮件地址 %s 发出了一封定时邮件, 当前时间是: %s%n" ,email, now); } }
.withIdentity("mailjob1", "mailgroup") mailgroup就是分组的意思。 比如一个系统有3个job 是备份数据库的,有4个job 是发邮件的,那么对他们进行分组,可以方便管理,类似于一次性停止所有发邮件的这样的操作.
import static 这种写法叫做静态导入,指的是导入某个
类的静态方法, 这样就可以直接使用了,而不是必须写成:
JobBuilder.newJob()
log4j 放在这里,只开放error以上的日志信息,否则看上去乱哄哄的
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE log4j:configuration SYSTEM "log4j.dtd"> <log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/"> <appender name="default" class="org.apache.log4j.ConsoleAppender"> <param name="target" value="System.out"/> <layout class="org.apache.log4j.PatternLayout"> <param name="ConversionPattern" value="[%p] %d{dd MMM hh:mm:ss.SSS aa} %t [%c]%n%m%n%n"/> </layout> </appender> <logger name="com.how2java"> <level value="error" /> </logger> <root> <level value="error" /> <appender-ref ref="default" /> </root> </log4j:configuration>
程序编程之旅公众号,关注后实时获知最新的教程和优惠活动,谢谢。
![]()
问答区域
2019-08-18
站长忘记说了导入Jar包了
1 个答案
滑落的星辰 跳转到问题位置 答案时间:2019-09-18
<!-- https://mvnrepository.com/artifact/org.quartz-scheduler/quartz --> <dependency> <groupId>org.quartz-scheduler</groupId> <artifactId>quartz</artifactId> <version>2.2.3</version> </dependency>
回答已经提交成功,正在审核。 请于
我的回答 处查看回答记录,谢谢
2019-08-05
关于log4j的配置
2019-04-03
要延时执行怎么办,我设了每隔10秒执行,并把重复次数设为0,可是立即执行了
2018-07-17
不错,刚好有需要
2018-04-10
站长牛逼!
提问之前请登陆
提问已经提交成功,正在审核。 请于
我的提问 处查看提问记录,谢谢
|