Quartz对任务调度的领域问题进行了高度的抽象,提出了调度器、任务和触发器这3个核心的概念,并在org.quartz通过接口和类对重要的这些核心概念进行描述。
应用场景:
任务调度在软件,各大网站经常用到,比如:每隔半个小时生成精华文章的RSS文件,每天凌晨统计论坛用户的积分排名,每隔30分钟执行锁定用户解锁任务。
对于一个典型的MIS系统来说,在每月1号凌晨统计上个月各部门的业务数据生成月报表,每半个小时查询用户是否已经有快到期的待处理业务……,这样的例子俯拾皆是,不胜枚举。
项目中应用及架构解析
以我最近做的一个项目为例,这个项目应用到后台系统定时对每天的的用户充值、银行卡绑定等进行核对,这是一项需要自动触发的任务,我们用Quartz来实现,与Timer,ScheduledExecutor相比,Quartz 可以满足更多更复杂的调度需求。
首先看一下类之间的调用关系:
InitJob–>WarningEngine–>WarningJob–>WarningJobExecuter
InitJob:
继承HttpServlet,用init和destroy方法
init方法,负责初始化Servlet对象
destory方法,当Servlet对象退出声明周期时,负责释放占有的资源
@SuppressWarnings("serial")
public class InitJob extends HttpServlet{
private final Logger logger = Logger.getLogger(InitJob.class);
public void init(){
System.out.println("job被加载!");
startWarningJob();//启动预警平台任务
}
public void startWarningJob(){
try {
new WarningEngine().startAllJobs();
} catch (Exception e) {
logger.error(e.getMessage());
}
}
@Override
public void destroy() {
try {