步骤 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", "admin@10086.com") //定义属性
.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>
HOW2J公众号,关注后实时获知最新的教程和优惠活动,谢谢。
问答区域
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的配置
2 个答案
写bug的程序猿 跳转到问题位置 答案时间:2023-03-22 可以说他也没啥用,跟输出语句sout有异曲同工之妙
我会努力学JAVA的 跳转到问题位置 答案时间:2019-08-18 log4j这个东西,你都学到这了,还不知道干嘛的, 就是打印日志用的啊,
回答已经提交成功,正在审核。 请于 我的回答 处查看回答记录,谢谢
2019-04-03
要延时执行怎么办,我设了每隔10秒执行,并把重复次数设为0,可是立即执行了
2018-07-17
不错,刚好有需要
2018-04-10
站长牛逼!
提问之前请登陆
提问已经提交成功,正在审核。 请于 我的提问 处查看提问记录,谢谢
|