spring+quartz新增,删除,暂停,恢复定时任务

spring配置

<bean id="scheduler"
		class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
	<!-- 	<property name="startupDelay" value="180"/>  启动服务器后延迟启动定时任务-->
</bean>

先定义SchedulerJob  javabean

public class ScheduleJob {
	private String jobId;//任务id
	private String jobName;//任务名称
	private String jobGroup;//任务分组
	private int jobStatus;//任务状态 0禁用 1启用 2删除
	private String cronExpression;//任务运行时间表达式
	private String jobDesc;//任务描述
	public String getJobId() {
		return jobId;
	}
	public void setJobId(String jobId) {
		this.jobId = jobId;
	}
	public String getJobName() {
		return jobName;
	}
	public void setJobName(String jobName) {
		this.jobName = jobName;
	}
	public String getJobGroup() {
		return jobGroup;
	}
	public void setJobGroup(String jobGroup) {
		this.jobGroup = jobGroup;
	}
	
	public int getJobStatus() {
		return jobStatus;
	}
	public void setJobStatus(int jobStatus) {
		this.jobStatus = jobStatus;
	}
	public String getCronExpression() {
		return cronExpression;
	}
	public void setCronExpression(String cronExpression) {
		this.cronExpression = cronExpression;
	}
	public String getJobDesc() {
		return jobDesc;
	}
	public void setJobDesc(String jobDesc) {
		this.jobDesc = jobDesc;
	}
}

定时器JOB管理类

public class JobManage {
    private static final Logger logger = LoggerFactory.getActionLog(JobManage.class);
    private TimedTaskService timedTaskService;
    
    public TimedTaskService getTimedTaskService() {
        return timedTaskService;
    }
    public void setTimedTaskService(TimedTaskService timedTaskService) {
        this.timedTaskService = timedTaskService;
    }
    private static SchedulerFactoryBean schedulerFactoryBean;
    private static Scheduler scheduler;
    static{
        schedulerFactoryBean = (SchedulerFactoryBean) BeanUtil.getBeanByClass(SchedulerFactoryBean.class);
        scheduler = schedulerFactoryBean.getScheduler();
    }
    /**
     * 初始化定时任务
     * @throws SchedulerException
     */
    public void initTask() throws SchedulerException {
        //Scheduler scheduler = schedulerFactoryBean.getScheduler();
        // 这里获取任务信息数据
        List<ScheduleJob> jobList = timedTaskService.getAllJob();//从数据库中读取
        for (ScheduleJob job : jobList) {
            addJob(job);
        }
    }
    /**
     * 添加一个任务
     * @param job
     */
    public void addJob(ScheduleJob job){
        try {
            TriggerKey triggerKey = TriggerKey.triggerKey(job.getJobName(), job.getJobGroup());
            // 获取trigger,即在spring配置文件中定义的 bean id="myTrigger"
            CronTrigger trigger = (CronTrigger) scheduler.getTrigger(triggerKey);
            // 不存在,创建一个
            if (null == trigger) {
                JobDetail jobDetail = JobBuilder.newJob(QuartzJobFactory.class)
                        .withIdentity(job.getJobName(), job.getJobGroup()).build();
                jobDetail.getJobDataMap().put("scheduleJob", job);
                // 表达式调度构建器
                CronScheduleBuilder scheduleBuilder = CronScheduleBuilder.cronSchedule(job.getCronExpression());
                // 按新的cronExpression表达式构建一个新的trigger
                trigger = TriggerBuilder.newTrigger().withIdentity(job.getJobName(), job.getJobGroup())
                        .withSchedule(scheduleBuilder).build();
                scheduler.scheduleJob(jobDetail, trigger);
            } else {
                // Trigger已存在,那么更新相应的定时设置
                // 表达式调度构建器
                CronScheduleBuilder scheduleBuilder = CronScheduleBuilder.cronSchedule(job.getCronExpression());
                // 按新的cronExpression表达式重新构建trigger
                trigger = trigger.getTriggerBuilder().withIdentity(triggerKey).withSchedule(scheduleBuilder).build();
                // 按新的trigger重新设置job执行
                scheduler.rescheduleJob(triggerKey, trigger);
            }
            if(job.getJobStatus()==0){
                pauseJob(job);
            }
            
        } catch (SchedulerException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }
    /**
     * 暂停一个job
     * @param scheduleJob
     * @throws SchedulerException
     */
    public void pauseJob(ScheduleJob scheduleJob){
        //Scheduler scheduler = schedulerFactoryBean.getScheduler();
        logger.info(scheduleJob.getJobName(),"定时任务暂停");
        JobKey jobKey = JobKey.jobKey(scheduleJob.getJobName(), scheduleJob.getJobGroup());
        try {
            scheduler.pauseJob(jobKey);
        } catch (SchedulerException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }
    /**
     * 恢复一个job
     * @param scheduleJob
     */
    public void resumeJob(ScheduleJob scheduleJob){
        logger.info(scheduleJob.getJobName(),"定时任务启动");
        //Scheduler scheduler = schedulerFactoryBean.getScheduler();
        JobKey jobKey = JobKey.jobKey(scheduleJob.getJobName(),scheduleJob.getJobGroup());
        try {
            scheduler.resumeJob(jobKey);
        } catch (SchedulerException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }
    /**
     * 删除一个任务
     * @param scheduleJob
     */
    public void removeJob(ScheduleJob job){
        logger.info(job.getJobName(),"删除定时任务");
        TriggerKey triggerKey = TriggerKey.triggerKey(job.getJobName(), job.getJobGroup());
        JobKey jobKey = JobKey.jobKey(job.getJobName(),job.getJobGroup());
        // 获取trigger,即在spring配置文件中定义的 bean id="myTrigger"
        //CronTrigger trigger = (CronTrigger) scheduler.getTrigger(triggerKey);
        try {
            scheduler.pauseTrigger(triggerKey);
            scheduler.unscheduleJob(triggerKey);
            scheduler.deleteJob(jobKey);
        } catch (SchedulerException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }
}
job工厂类

@DisallowConcurrentExecution //只有上一个人任务执行完毕才可以执行下一次任务
public class QuartzJobFactory implements Job{
	private static final Logger logger = LoggerFactory.getActionLog(QuartzJobFactory.class);
	@Override
	public void execute(JobExecutionContext context){
		// TODO Auto-generated method stub
		try{
			ScheduleJob scheduleJob = (ScheduleJob)context.getMergedJobDataMap().get("scheduleJob");
			logger.info(scheduleJob.getJobName(),"任务开始");
			((TaskService) BeanUtil.getBean(scheduleJob.getJobName())).exe();
			logger.info(scheduleJob.getJobName(),"任务结束");
		}catch(Exception e){
			e.printStackTrace();
		}
		//logger.info("任务结束", scheduleJob.getJobName());
	}

}
具体业务接口

public interface TaskService {
	/**
	 * 具体业务逻辑
	 */
	public abstract void exe();
}
实现上面的接口,在spring配置bean

<bean id="test" class="com.cmos.ccscore.service.timedTask.impl.Test" parent="baseService">
 </bean>

在数据库中插入记录.

spring获取bean工具类

public class BeanUtil implements ApplicationContextAware{
	private static ApplicationContext context;
	
	@Override
	public void setApplicationContext(ApplicationContext arg0) throws BeansException {
		// TODO Auto-generated method stub
		context = arg0;
	}
	public static Object getBean(String beanName){
		return context.getBean(beanName);
	}
	public static <T> Object getBeanByClass(Class<T> c){
		return context.getBean(c);
	}
}

监听器用于服务启动初始化定时任务

public class TaskListener implements ServletContextListener{
	private static final Logger logger = LoggerFactory.getActionLog(TaskListener.class);
	@Override
	public void contextDestroyed(ServletContextEvent arg0) {
		// TODO Auto-generated method stub
	}

	@Override
	public void contextInitialized(ServletContextEvent arg0) {

		logger.info("TaskListener", "定时任务初始化");
		JobManage m = (JobManage) BeanUtil.getBean("jobManage");
		try {
			m.initTask();
		} catch (SchedulerException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
	}

}
TimedTaskService 定时任务服务类就是获取前端请求对数据库的操作,需注入JobManage类来对定时任务进行管理

最终页面效果


  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值