quartz多个定时任务实现方式

1、pom.xml

<!-- quartz 定时任务 -->
        <dependency>
            <groupId>org.quartz-scheduler</groupId>
            <artifactId>quartz</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context-support</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-tx</artifactId>
        </dependency>
        <!-- quartz 定时任务 -->

2、生成job的工厂交给spring管理

import org.quartz.spi.TriggerFiredBundle;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.config.AutowireCapableBeanFactory;
import org.springframework.context.annotation.Configuration;
import org.springframework.scheduling.quartz.AdaptableJobFactory;


@Configuration
public class MyJobFactory extends AdaptableJobFactory {
    
    @Autowired
    private AutowireCapableBeanFactory capableBeanFactory;
    
    @Override
    protected Object createJobInstance(TriggerFiredBundle bundle)throws Exception {
        //调用父类的方法
        Object jreateJobInstance = super.createJobInstance(bundle);
        //进行注入
        capableBeanFactory.autowireBean(jreateJobInstance);    
        return jreateJobInstance;
    }
}

3、任务调度器 Scheduler

mport java.io.IOException;
import org.quartz.JobDetail;
import org.quartz.Trigger;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.scheduling.annotation.EnableScheduling;
import org.springframework.scheduling.quartz.CronTriggerFactoryBean;
import org.springframework.scheduling.quartz.JobDetailFactoryBean;
import org.springframework.scheduling.quartz.SchedulerFactoryBean;
/**
 * 任务调度处理 两个任务调度 firstTrigger 和 secondTrigger
 * 
 */

@Configuration
@EnableScheduling
public class QuartzScheduler {
    @Autowired
    private MyJobFactory myJobFactory;
    
    @Bean 
    public SchedulerFactoryBean schedulerFactoryBean(Trigger firstTrigger,Trigger secondTrigger) throws IOException {
        SchedulerFactoryBean factory = new SchedulerFactoryBean();
        factory.setOverwriteExistingJobs(true); 
        // 延时启动 
        factory.setStartupDelay(20); 
        // 自定义Job Factory,用于Spring注入
        factory.setJobFactory(myJobFactory);
        factory.setTriggers(firstTrigger,secondTrigger); //设置多个定时任务配置
        return factory; 
     }
     
    @Bean(name = "firstJobDetail") 
    public JobDetailFactoryBean firstJobDetail() {
        JobDetailFactoryBean jobDetail = new JobDetailFactoryBean(); 
        jobDetail.setJobClass(SchedulerQuartzJob.class); 
        return jobDetail; 
    }
     
    @Bean(name = "firstTrigger") 
    public CronTriggerFactoryBean firstTriggerFactoryBean(JobDetail firstJobDetail) { 
        CronTriggerFactoryBean trigger = new CronTriggerFactoryBean();
        //trigger.setCronExpression("0/5 * * * * ?"); // 每五秒执行一次
        trigger.setCronExpression("0 0 5 * * ?"); //每天凌晨5点钟触发一次
        trigger.setJobDetail(firstJobDetail);
        return trigger; 
    }
    
    @Bean(name = "secondJobDetail") 
    public JobDetailFactoryBean uploadJobDetail() {
        JobDetailFactoryBean jobDetail = new JobDetailFactoryBean(); 
        jobDetail.setJobClass(StatisticsBrodcastJob.class); 
        return jobDetail; 
    }
     
    @Bean(name = "secondTrigger") 
    public CronTriggerFactoryBean secondTriggerFactoryBean(JobDetail secondJobDetail) { 
        CronTriggerFactoryBean trigger = new CronTriggerFactoryBean();
        //trigger.setCronExpression("0/10 * * * * ?"); // 每6秒执行一次
        trigger.setCronExpression("0 58 23 * * ?"); //每天23点58分触发一次
        trigger.setJobDetail(secondJobDetail);
        return trigger; 
    }
    
}

4、任务类:能够注入业务类,两任务  SchedulerQuartzJob 和

import org.quartz.Job;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.transaction.annotation.Transactional;
import com.byd.masoct.common.utils.DateUtils;
import com.byd.masoct.pojo.auto.MasoctBroadcast;
import com.byd.masoct.service.BoradcastServive;

/**
 * 实现定时任务job接口
 *
 */
@Transactional //添加事务
public class SchedulerQuartzJob implements Job {
    protected static Logger logger=LoggerFactory.getLogger(SchedulerQuartzJob.class);
    @Autowired
    private RedisTemplate<String, String>  redisTemplate;

   //注入业务service层
    @Autowired
    private 业务service  业务service;
    
    private static final String LOCK = "boradcast-job-lock";

    private static final String KEY = "boradcastlock";
    @Override
    public void execute(JobExecutionContext arg0)throws JobExecutionException {
        System.out.println("SchedulerQuartzJob任务开始:" + System.currentTimeMillis());
         boolean lock = false;
        try {
            //使用redis分布式锁解决quartz定时任务部署重复执行问题
            lock = redisTemplate.opsForValue().setIfAbsent(KEY, LOCK);
            logger.info("SchedulerQuartzJob是否获取到锁:" + lock);
            if(lock){
                try { 
                  //业务处理   //业务处理   //业务处理


                } catch (Exception e) {
                    e.printStackTrace();
                }
            }else {
                logger.info("SchedulerQuartzJob没有获取到锁,不执行任务!");
               
            }
        } finally{
            if (lock) {
                redisTemplate.delete(KEY);
                logger.info("SchedulerQuartzJob任务结束,释放锁!");
            } else {
                logger.info("SchedulerQuartzJob没有获取到锁,无需释放锁!");
            }

        }
        System.out.println("SchedulerQuartzJob任务结束:" + System.currentTimeMillis());
        
    }

}
 

任务二; 

 

import java.util.List;

import org.quartz.Job;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.transaction.annotation.Transactional;

import com.byd.masoct.common.enums.ResultEnum;
import com.byd.masoct.common.utils.JsonUtils;
import com.byd.masoct.common.utils.RedisUtil;
import com.byd.masoct.pojo.auto.MasoctBroadcast;
import com.byd.masoct.service.BoradcastServive;

/**
 *
 * @version 创建时间:2019年4月15日 下午4:59:56
 * 类说明
 */
@Transactional //添加事务
public class StatisticsBrodcastJob implements Job{
    protected static Logger logger=LoggerFactory.getLogger(StatisticsBrodcastJob.class);
    @Autowired
    private RedisTemplate<String, String>  redisTemplate;
   //注入业务service层
    @Autowired
    private 业务service  业务service;

    
    @Value("${MASOCTBROADCAST_NUMBER_LIST}")
    private String MASOCTBROADCAST_NUMBER_LIST;
    
    private static final String LOCK = "statisticsBrodcast-job-lock";

    private static final String KEY = "statisticsBrodcastlock";
    @Override
    public void execute(JobExecutionContext arg0) throws JobExecutionException {
        System.out.println("StatisticsBrodcastJob任务1执行....");
        
        boolean lock = false;
        try {
            //使用redis分布式锁解决quartz定时任务部署重复执行问题
            lock = redisTemplate.opsForValue().setIfAbsent(KEY, LOCK);
            logger.info("StatisticsBrodcastJob是否获取到锁:" + lock);
            if(lock){
                
                try {
                  //业务处理
                    
                } catch (Exception e) {
                    //添加自定义异常信息
                    e.printStackTrace();
                }
            }else {
                logger.info("没有获取到锁,不执行任务!");
              
            }
        } finally{
            if (lock) {
               redisTemplate.delete(KEY);
               logger.info("任务结束,释放锁!");
           } else {
               logger.info("没有获取到锁,无需释放锁!");
           }

        }
        System.out.println("StatisticsBrodcastJob任务结束:" + System.currentTimeMillis());
        
    }

}
 

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值