springboot整合quartz+实现定时任务详细代码

定时任务代码:
@Configuration
public class QuartzConfigration {

@Bean(name = "firstJobDetail")
public MethodInvokingJobDetailFactoryBean firstJobDetail(**TimerUpdateServiceImpl** firstJob) {
	MethodInvokingJobDetailFactoryBean jobDetail = new MethodInvokingJobDetailFactoryBean();
	// 是否并发执行
	jobDetail.setConcurrent(false);
	// 为需要执行的实体类对应的对象
	jobDetail.setTargetObject(firstJob);
	// 需要执行的方法
	jobDetail.setTargetMethod("timerGenerateTask");
	return jobDetail;
}
// 配置触发器2
@Bean(name = "firstTrigger")
public CronTriggerFactoryBean firstTrigger(JobDetail firstJobDetail) {
	CronTriggerFactoryBean trigger = new CronTriggerFactoryBean();
	trigger.setJobDetail(firstJobDetail);
	// cron表达式
	// 每天早上5点59分执行
	trigger.setCronExpression("0 10 00 * * ?");
	return trigger;
}
@Bean(name = "secondJobDetail")
public MethodInvokingJobDetailFactoryBean secondJobDetail(TimerUpdateServiceImpl secondJob) {
	MethodInvokingJobDetailFactoryBean jobDetail = new MethodInvokingJobDetailFactoryBean();
	// 是否并发执行
	jobDetail.setConcurrent(false);
	// 为需要执行的实体类对应的对象
	jobDetail.setTargetObject(secondJob);
	// 需要执行的方法
	jobDetail.setTargetMethod("timerUpdateStatus");
	return jobDetail;
}
// 配置触发器2
@Bean(name = "secondTrigger")
public CronTriggerFactoryBean secondTrigger(JobDetail secondJobDetail) {
	CronTriggerFactoryBean trigger = new CronTriggerFactoryBean();
	trigger.setJobDetail(secondJobDetail);
	// cron表达式
	// 每天早上5点59分执行
	trigger.setCronExpression("0 59 05 * * ?");
	return trigger;
}
@Bean(name = "thirdJobDetail")
public MethodInvokingJobDetailFactoryBean thirdJobDetail(TimerUpdateServiceImpl thirdJob) {
	MethodInvokingJobDetailFactoryBean jobDetail = new MethodInvokingJobDetailFactoryBean();
	// 是否并发执行
	jobDetail.setConcurrent(false);
	// 为需要执行的实体类对应的对象
	jobDetail.setTargetObject(thirdJob);
	// 需要执行的方法
	jobDetail.setTargetMethod("timerUpdateStatus2");
	return jobDetail;
}
// 配置触发器3
@Bean(name = "thirdTrigger")
public CronTriggerFactoryBean thirdTrigger(JobDetail thirdJobDetail) {
	CronTriggerFactoryBean trigger = new CronTriggerFactoryBean();
	trigger.setJobDetail(thirdJobDetail);
	// 设置任务启动延迟
	trigger.setStartDelay(0);
	// 每5秒执行一次
	// trigger.setRepeatInterval(5000);
	// 每天23点50执行
	trigger.setCronExpression("0 50 23 * * ?");
	return trigger;
}
@Bean(name = "fourthJobDetail")
public MethodInvokingJobDetailFactoryBean fourthJobDetail(TimerUpdateServiceImpl fourthJob) {
	MethodInvokingJobDetailFactoryBean jobDetail = new MethodInvokingJobDetailFactoryBean();
	// 是否并发执行
	jobDetail.setConcurrent(false);
	// 为需要执行的实体类对应的对象
	jobDetail.setTargetObject(fourthJob);
	// 需要执行的方法
	jobDetail.setTargetMethod("timerDeleteMsg");
	return jobDetail;
}
// 配置Scheduler
@Bean(name = "scheduler")
public SchedulerFactoryBean schedulerFactory(Trigger firstTrigger,Trigger secondTrigger, Trigger thirdTrigger) {
	SchedulerFactoryBean bean = new SchedulerFactoryBean();
	// 延时启动,应用启动1秒后
	bean.setStartupDelay(1);
	// 注册触发器
	bean.setTriggers(firstTrigger, secondTrigger, thirdTrigger);
	return bean;
}

}

//**************************************************************************************************//
工具类:
@Component
public class SpringUtil implements ApplicationContextAware {

private static ApplicationContext applicationContext;

@Override
public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
if (SpringUtil.applicationContext == null) {
SpringUtil.applicationContext = applicationContext;
}
}

//获取applicationContext
public static ApplicationContext getApplicationContext() {
return applicationContext;
}

//通过name获取 Bean.
public static Object getBean(String name) {
return getApplicationContext().getBean(name);
}

//通过class获取Bean.
public static T getBean(Class clazz) {
return getApplicationContext().getBean(clazz);
}

//通过name,以及Clazz返回指定的Bean
public static T getBean(String name, Class clazz) {
return getApplicationContext().getBean(name, clazz);
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值