Springシリーズ-springbootはクォータータイミングタスクを統合します

前書き

この記事では、主にSpringシリーズのSpringboot統合クォータータイミングタスクを紹介します。これらは、jarパッケージの追加、タイミングタスク構成クラスの作成、実行する特定のタスクの作成の3つの部分に大別されます。この記事を読んだ後、皆さんのお役に立てば幸いです。

1つは、jarパッケージを追加する

 <!--quartz定时任务-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-quartz</artifactId>
        </dependency>

2つ目は、タイミングタスクの構成クラスを作成することです。

このクラスが実行するタスクと実行するタイミングとして理解できます。

package com.vale.info.server.quartz;

import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.vale.info.server.dao.CronDao;
import com.vale.info.server.entity.Cron;
import com.vale.info.server.global.RedisConstants;
import com.vale.info.server.util.InfoException;
import com.vale.info.server.util.RedisUtils;
import lombok.extern.slf4j.Slf4j;
import org.quartz.*;
import org.springframework.scheduling.quartz.SchedulerFactoryBean;
import org.springframework.stereotype.Component;

import javax.annotation.Resource;

/**
 * TODO
 *
 * @author wasin
 * @version 1.0
 * @date 2020/9/7 19:33
 */
@Component
@Slf4j
public class TaskFileScheduler {

    @Resource
    private SchedulerFactoryBean schedulerFactoryBean;

    private Integer taskId;

    public void setTaskId(Integer taskId){
        this.taskId=taskId;
    }

    @Resource
    private Scheduler scheduler;

    /**
     * 设置任务的执行时间
     * @param scheduler
     * RedisConstants. 相关的是我自己定义的静态变量 为这个定时任务添加任务的名称 和分组
     * 后期如果需要删除时则找到相关的名称去删除即可
     * @throws SchedulerException
     */
    private void setTaskExecuteDate(Scheduler scheduler) throws SchedulerException {
        log.info("设置任务的执行时间 taskId={},任务名称={},分组名称={}",taskId,String.format(RedisConstants.QUARTER_JOB_NAME,taskId),String.format(RedisConstants.QUARTER_JOB_GROUP,taskId));
        JobDetail jobDetail = JobBuilder.newJob(TaskJob.class).withIdentity(String.format(RedisConstants.QUARTER_JOB_NAME,taskId), String.format(RedisConstants.QUARTER_JOB_GROUP,taskId)).build();
         //2020-9-18 18:18:18秒执行这个任务
        CronScheduleBuilder scheduleBuilder = CronScheduleBuilder.cronSchedule("18 18 18 18 9 ? 2020");
        JobDataMap jobDataMap=new JobDataMap();

        jobDataMap.put("taskId",this.taskId);
        CronTrigger cronTrigger = TriggerBuilder.newTrigger().withIdentity(String.format(RedisConstants.QUARTER_TRIGGER_NAME,taskId), String.format(RedisConstants.QUARTER_TRIGGER_GROUP,taskId))
                .usingJobData(jobDataMap).withSchedule(scheduleBuilder).build();
        scheduler.scheduleJob(jobDetail,cronTrigger);
    }

    //业务代码中掉用这个方法就可以添加这个定时任务
    public void scheduleJobs(Integer taskId) throws SchedulerException {
        if(taskId==null){
            throw new InfoException("定时任务id不可为空");
        }
        this.taskId=taskId;
        Scheduler scheduler = schedulerFactoryBean.getScheduler();
        setTaskExecuteDate(scheduler);
    }

    /**
     * 删除定时任务
     * @param croId  定时任务id
     * @param jobName 任务名称  就是任务id
     * @param jobGroup 任务分组 就是任务id
     */
    public void delJob(Integer croId,String jobName, String jobGroup) {
        try {
          log.info("删除定时任务 jobName={},jobGroup={}",jobName,jobGroup);
            this.taskId=Integer.valueOf(jobName);
            jobName=String.format(RedisConstants.QUARTER_TRIGGER_NAME,jobName);
            jobGroup=String.format(RedisConstants.QUARTER_TRIGGER_GROUP,jobGroup);
            // TriggerKey 定义了trigger的名称和组别 ,通过任务名和任务组名获取TriggerKey
            TriggerKey triggerKey = TriggerKey.triggerKey(jobName,jobGroup);
            if(triggerKey!=null){
                // 停止触发器
                scheduler.resumeTrigger(triggerKey);
                // 移除触发器
                scheduler.unscheduleJob(triggerKey);
                // 移除任务
                scheduler.deleteJob(JobKey.jobKey(jobName,jobGroup));
                log.info("定时任务删除成功");
            }
        } catch (SchedulerException e) {
            e.printStackTrace();
        }

    }

}

3、特定のタスクを作成します

これは、このタスクで何をするかとして理解できます。上記で定義されているのは、いつ実行するか、誰が実行するかです。

package com.vale.info.server.quartz;

import com.vale.info.server.dao.CronDao;
import com.vale.info.server.entity.Cron;
import com.vale.info.server.entity.Task;
import com.vale.info.server.global.UdpConstans;
import com.vale.info.server.util.ReadFile;
import com.vale.info.server.util.RedisUtils;
import com.vale.info.server.util.UdpFileClient;
import lombok.extern.slf4j.Slf4j;
import org.quartz.Job;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;
import org.springframework.stereotype.Component;

import javax.annotation.Resource;
import java.io.IOException;

/**
 * TODO
 * 定义一个需要去执行的任务
 * @author wasin
 * @version 1.0
 * @date 2020/9/7 19:25
 */
@Component
@Slf4j
public class TaskJob implements Job {

    //这些参数都可以在上面定义的类中传过来

    private Integer taskId;

    public void setTaskId(Integer taskId) {
        this.taskId = taskId;
    }
    @Override
    public void execute(JobExecutionContext jobExecutionContext) {
        log.info("定时任务执行 taskId={}",taskId);
        //执行具体的业务逻辑 

    }
}

終わり

終わりを見てくれてありがとう。終わりです。出発する前と同じように。何か問題があれば訂正してください。

おすすめ

転載: blog.51cto.com/14969174/2542936