quartz2.3.0(八)使用日历排除不应该执行任务的时间段

Job任务类

package org.quartz.examples.example8;

import java.util.Date;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.quartz.Job;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;
import org.quartz.JobKey;

/**
 * 这只是一个简单的工作,它会被例1多次触发
 */
public class SimpleJob implements Job {

    private static Logger LOG = LoggerFactory.getLogger(SimpleJob.class);

    //必须要有public修饰的无参构造函数
    public SimpleJob() {
    }

  //定时器执行方法
    public void execute(JobExecutionContext context)
        throws JobExecutionException {

        // 这个作业只是打印出它的作业名称以及它运行的日期和时间
        JobKey jobKey = context.getJobDetail().getKey();
        LOG.info("SimpleJob says: " + jobKey + " executing at " + new Date());
    }

}

调度器类

package org.quartz.examples.example8;

import static org.quartz.DateBuilder.dateOf;
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.SchedulerFactory;
import org.quartz.SchedulerMetaData;
import org.quartz.SimpleTrigger;
import org.quartz.examples.example2.SimpleJob;
import org.quartz.impl.StdSchedulerFactory;
import org.quartz.impl.calendar.AnnualCalendar;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.util.Calendar;
import java.util.Date;
import java.util.GregorianCalendar;

/**
 * 这个示例将演示如何使用日历排除不应该进行调度的时间段,比如假期。
 */
public class CalendarExample {

    final Logger LOG = LoggerFactory.getLogger(CalendarExample.class);

    public void run() throws Exception {
        // 初始化一个调度工厂,并实例化一个调度类
        SchedulerFactory sf = new StdSchedulerFactory();
        Scheduler sched = sf.getScheduler();

        // 将假期日历添加到日程中
        AnnualCalendar holidays = new AnnualCalendar();

        // 2005年6月4日
        Calendar fourthOfJuly = new GregorianCalendar(2005, 6, 4);
        holidays.setDayExcluded(fourthOfJuly, true);
        // 2005年9月31日
        Calendar halloween = new GregorianCalendar(2005, 9, 31);
        holidays.setDayExcluded(halloween, true);
        // 2005年11月25日
        Calendar christmas = new GregorianCalendar(2005, 11, 25);
        holidays.setDayExcluded(christmas, true);

        // 告诉调度器我们的假期安排
        sched.addCalendar("holidays", holidays, false, false);

        // 安排一项工作每小时运行一次:10月31日10点0分0秒 ,秒、分、小时、日、月
        Date runDate = dateOf(0, 0, 10, 31, 10);

        JobDetail job = newJob(SimpleJob.class).withIdentity("job1", "group1").build();
        // 间隔1小时运行一次,无限循环
        SimpleTrigger trigger = newTrigger().withIdentity("trigger1", "group1").startAt(runDate)
                .withSchedule(simpleSchedule().withIntervalInHours(1).repeatForever()).modifiedByCalendar("holidays")
                .build();
        Date firstRunTime = sched.scheduleJob(job, trigger);

        // 由于10月31日是万圣节,所以我们将在之后一天11月1日运行任务
        LOG.info(job.getKey() + " will run at: " + firstRunTime + " and repeat: " + trigger.getRepeatCount()
                + " times, every " + trigger.getRepeatInterval() / 1000 + " seconds");

        sched.start();

        // 睡眠30秒
        Thread.sleep(30L * 1000L);

        sched.shutdown(true);
        LOG.info("------- Shutdown Complete -----------------");

        SchedulerMetaData metaData = sched.getMetaData();
        LOG.info("Executed " + metaData.getNumberOfJobsExecuted() + " jobs.");

    }

    public static void main(String[] args) throws Exception {

        CalendarExample example = new CalendarExample();
        example.run();
    }

}

原文地址:https://www.cnblogs.com/zhuwenjoyce/p/11186461.html

时间: 2024-07-31 19:08:35

quartz2.3.0(八)使用日历排除不应该执行任务的时间段的相关文章

axure RP Pro7.0加载日历控件的步骤

就可以把日历控件加载进来 axure RP Pro7.0加载日历控件的步骤

quartz2.3.0(十)xml配置方式定义quartz定时任务

1.新增pom依赖 除了按照<quartz2.3.0系列目录——带您由浅入深全面掌握quartz2.3.0>添加依赖之外,pom.xml里新增加依赖: <dependency> <groupId>opensymphony</groupId> <artifactId>quartz-all</artifactId> <version>1.6.3</version> </dependency> <d

quartz2.3.0(十五)执行、暂停、继续执行、清除,花式操作数据库中持久化的job任务

前提准备: 先在数据库中建立quartz需要的11张表(我这里用的是Oracle数据库),根据不同的数据库quartz分别提供了不同的初始化sql文件,sql文件路径在 quartz-2.3.0-SNAPSHOT-0724\src\org\quartz\impl\jdbcjobstore下: ScheduleBuilder是trigger触发器的触发规则定制类,旗下有4种触发器实现类:  CalendarIntervalScheduleBuilder.CronScheduleBuilder.Da

Android 4.0之后的日历控件拥挤的解决办法

本意是想做成这个样子的控件: 发现使用datepicker之后,效果完全不同,把整个日历都显示出来了.非常拥挤. 在datepicker中加入android:calendarViewShown="false"就OK了

quartz2.3.0(五)制定错过执行任务的misfire策略

感谢兄台: <quartz-misfire 错失.补偿执行> misfire定义 misfire:被错过的执行任务策略 misfire重现——CronTrigger job任务类: package org.quartz.examples.example5; import org.quartz.DisallowConcurrentExecution; import org.quartz.Job; import org.quartz.JobDataMap; import org.quartz.Jo

quartz2.3.0(十一)任务执行中故障情况,可设置重新执行任务

任务类 package org.quartz.examples.example11; import org.quartz.Job; import org.quartz.JobExecutionContext; import org.quartz.JobExecutionException; import org.quartz.JobKey; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import java.util.Date

ASP.NET Core 2.0 : 八.图说管道

本文通过一张GIF动图来继续聊一下ASP.NET Core的请求处理管道,从管道的配置.构建以及请求处理流程等方面做一下详细的研究.(ASP.NET Core系列目录) 一.概述 上文说到,请求是经过 Server监听=>处理成httpContext=>Application处理生成Response. 这个Application的类型RequestDelegate本质是 public delegate Task RequestDelegate (HttpContext context); ,即

quartz2.3.0(九)job任务监听器,监听任务执行前、后、取消手动处理方法

job1任务类 package org.quartz.examples.example9; import java.util.Date; import org.quartz.Job; import org.quartz.JobExecutionContext; import org.quartz.JobExecutionException; import org.quartz.JobKey; import org.slf4j.Logger; import org.slf4j.LoggerFact

Quartz的基本使用之入门(2.3.0版本)

一.Quartz可以用来做什么 Quartz是一个强大任务调度框架,我工作时候会在这些情况下使用到quartz框架,当然还有很多的应用场景,在这里只列举2个实际用到的 餐厅系统会在每周四晚上的22点自动审核并生成报表 人事系统会在每天早晨8点给有待办的人员自动发送Email提醒 二.使用Quartz之前的准备 1.建立一个Maven项目 2.引入quartz的依赖 使用quartz,我们仅仅需要在maven的pom文件中添加依赖即可.我使用的是现在最新的一个版本2.3.0,大家可以在maven的