欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

quartz+corn表达式实现定时调度任务

程序员文章站 2022-10-03 17:15:46
关于MVC中得定时调度任务想起之前做项目得时候写过定时调度任务,这里做一下记录以后用到的时候方便查阅相关依赖功能快捷键合理的创建标题,有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列表创建一个表格设定内容居中、居左、居右SmartyPants创建一个自定义列表如何创建一个注脚注释也是必不可少的KaTeX数学公式新的甘特图功能,丰富你的文章UML 图表FLowchart流程图导出与导入导出导入想起之前做项目得时候写过定时调度任务,这里做一下记录以后用到的时候方便查阅...

想起之前做项目得时候写过定时调度任务,这里做一下记录以后用到的时候方便查阅

语法上来说还是比较简单的底层实际上是基于反射的,关于反射属于基础范围不做阐述。

相关依赖

    <!-- quartz -->
   <dependencycs>
    <dependency>
        <groupId>org.quartz-scheduler</groupId>
        <artifactId>quartz</artifactId>
        <version>2.2.0</version>
    </dependency>
     <dependency>
     <groupId>org.jodd</groupId>
        <artifactId>jodd-all</artifactId>
        <version>5.0.13</version>
    </dependency></dependencycs>
           

相关业务代码

启动监听

    public class TimeTaskListener implements ServletContextListener {
            @Override
    public void contextInitialized(ServletContextEvent sce) {
        // TODO Auto-generated method stub
        if(taskSwitch) {
            //每日定时任务启动
            ScheduleCommonByDayLoad.run();
         
        }
    }
    //销毁
    @Override
    public void contextDestroyed(ServletContextEvent sce) {
        // TODO Auto-generated method stub
        if(taskSwitch) {
        
            //销毁每日定时 任务
            ScheduleCommonByDayLoad.stop();
        }
    }
    
            }

业务绑定类

有关定时调度任务的具体的类

 package ***.***.***.***.***.quartz.regular;
			import org.apache.log4j.Logger;
		import org.quartz.*;
		import org.quartz.impl.StdSchedulerFactory;
	/**
		* 每日调度的执行 类
		*/
public class ScheduleCommonByDayLoad {

    //定时调度接口'
    private static Scheduler sched;

    private static Logger log = Logger.getLogger(ScheduleCommonByDayLoad.class);
    static{
        //创建工厂调度
        SchedulerFactory sfact = new StdSchedulerFactory();
        try{
            sched = sfact.getScheduler();
        }catch (Exception e){
            e.printStackTrace();
            log.error("创建定时调度计划对象异常,报错栈:" + e.toString());
        }
    }

    /**
      执行方法
        每天24点执行 一次   0 0 23 * * ?   测试每5秒钟执行一次
     	cron表达式基本的规则为 秒分时日月周年 可以百度一下,在线生成
     */
    public  static  void run(){
        log.error("==每日定时调度启动====");
        try {
            JobDetail jobDetail = JobBuilder.newJob((Class<? extends Job>) ScheduleCommonByDayJob.class)
                    .withIdentity("dayJob", "group10").build();
            CronTrigger trigger = TriggerBuilder.newTrigger().withIdentity("trigger", "group10")
                    // 每一分钟
                    .withSchedule(CronScheduleBuilder.cronSchedule("0 1 0 * * ?")).build();
            sched.start();
            sched.scheduleJob(jobDetail, trigger);
        }catch (Exception e){
            e.printStackTrace();
            log.error("每日定时器异常。");
            log.error("每日定时器报错栈:" + e.toString());
        }

    }

    //结束方法
    public  static void stop(){
        log.error("每日调度定时器销毁");
        try{
            sched.shutdown();
        }catch (Exception e){
            e.printStackTrace();
            log.error("每日定时器异常停止,报错找:"+e.toString());
        }
    }

}

代码绑定

/  代码绑定
package ***.***.****.***.**.quartz;

import org.apache.log4j.Logger;
import org.quartz.CronScheduleBuilder;
import org.quartz.CronTrigger;
import org.quartz.Job;
import org.quartz.JobBuilder;
import org.quartz.JobDetail;
import org.quartz.Scheduler;
import org.quartz.SchedulerException;
import org.quartz.SchedulerFactory;
import org.quartz.TriggerBuilder;
import org.quartz.impl.StdSchedulerFactory;

/**
* 定时调用邮箱读取job
*
* @author ***
*
*/
public class ScheduleReadEmailLoad {

    // 定时调度接口
    private static Scheduler sched;

    private static Logger log = Logger.getLogger(ScheduleReadEmailLoad.class);

    static {

        // 创建调度工厂对象
        SchedulerFactory sfact = new StdSchedulerFactory();
        try {

            sched = sfact.getScheduler();

        } catch (Exception e) {
            e.printStackTrace();
            log.error("创建定时调度计划对象异常,报错栈:" + e.toString());
        }
    }

    // 执行方法
    public static void run() {

        log.error("====读取邮箱定时器启动====");

        try {
            JobDetail jobDetail = JobBuilder.newJob((Class<? extends Job>) ScheduleReadEmailJob.class)
                    .withIdentity("emailJob", "group1").build();
            CronTrigger trigger = TriggerBuilder.newTrigger().withIdentity("trigger", "group1")
                    .withSchedule(CronScheduleBuilder.cronSchedule("0 0/1 * * * ?")).build();// 每一分钟

            sched.start();
            sched.scheduleJob(jobDetail, trigger);

        } catch (Exception e) {
            // TODO: handle exception
            log.error("读取邮箱定时器异常。");
            log.error("读取邮箱定时器报错栈:" + e.toString());
        }

    }

    // 结束方法
    public static void stop() {
        log.error("====读取邮箱定时器销毁====");
        try {
            sched.shutdown();
        } catch (SchedulerException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
            log.error("定时器停止异常,报错栈:" + e.toString());
        }
    }

}

附带cron在线生成表达式的地址https://cron.qqe2.com/

后面有空的话会继续更新一些工作中遇到的问题和解决方法~~~·

本文地址:https://blog.csdn.net/qq_43530309/article/details/107486657

相关标签: Java后端 java