spring boot根据动态的corn表达式执行定时任务

本文介绍了如何在Spring Boot项目中使用Quartz框架配置动态的Cron表达式来执行定时任务。相较于@Scheduled注解,Quartz提供了更强大的调度功能,适合需要从数据库读取Cron表达式的情况。文章详细讲解了配置Scheduler、创建JobDetail和CronTrigger的过程,并解释了如何实现Job接口以确保任务在指定时间自动执行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

spring boot配置定时任务本人已知的有两种方法,一种是使用注解@Scheduled,使用这个时需要在spring boot的启动类上添加@EnableScheduling注解以及在使用类中添加@Component方能使用,只需要了解corn的表达式便可以配置定时任务执行的时间。
但是如果是配置动态的corn表达式,此方法就不是很合适,这时需要用到quart定时器框架。
Quartz是纯Java实现,而且作为Spring的默认调度框架,由于Quartz的强大的调度功能、灵活的使用方式、还具有分布式集群能力,可以说Quartz出马,可以搞定一切定时任务调度!
在这里插入图片描述
本人自己的项目中涉及到定时推送数据任务场景,corn的表达式都需要从数据库读取,所以便采用了quart框架。

@Configuration
public class ShareResAllocaJobConfig implements ApplicationListener<ContextRefreshedEvent>{
   
	
	@Autowired
    private ShareResQuartzScheduler quartzScheduler;
	
	@Autowired
    private SharePlanService sharePlanService;


    /**
     * 初始启动quartz
     */
    public void onApplicationEvent(ContextRefreshedEvent event) {
   
    	try {
   
        	SharePlan sharePlan = new SharePlan();
        	sharePlan.setShareStatus(-1);
        	List<SharePlan> sharePlanList = sharePlanService.selectSharePlanByStatus(sharePlan);
        	if (sharePlanList != null && sharePlanList.size() > 0) {
   
        		for (SharePlan sharePlan2 : sharePlanList) {
   
        			String executePlan = sharePlan2.getExecutePlan();
        			if (StringUtils.isNotBlank(sharePlan2.getInDataSourceId()) && StringUtils.isNotBlank(executePlan)) {
   
        				executePlan = QuartzCronUtils.translateStringToCronExpression(executePlan);
                        //查询所有运行中的任务   把任务添加到任务管理器,这里便从数据库中查询动态的corn表达式存入接下来的调度任务对象中
                        quartzScheduler.addJob(SharePlanJobDetail.class, sharePlan2.getShareId(), Constants.GROUP_NAME, executePlan);

        			    if (sharePlan2.getShareStatus() < 1) {
   
        			    	quartzScheduler.pauseJob(sharePlan2.getShareId(), Constants.GROUP_NAME);//暂停任务
        			    }
        			}
				} 
        	}
		} catch (Exception e) {
   
			e.printStackTrace();
		}
    	
        System.out.println("任务已
Java中,我们可以使用Quartz框架来实现数据驱动的cron表达式,并配置定时任务Quartz是一个开源的任务调度框架,它允许你在Java应用中方便地安排和管理定期执行的工作。 以下是基本步骤: 1. **添加依赖**:首先,在你的项目中引入QuartzSpring的依赖,如果使用Spring Boot,可以在pom.xml文件中添加: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-quartz</artifactId> </dependency> ``` 2. **配置启动类**:在Spring Boot的启动类中,启用Quartz集成: ```java @SpringBootApplication @EnableScheduling // 开启Spring的调度功能 public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } } ``` 3. **编写Job和Trigger**:你需要创建一个实现了`org.quartz.Job`接口的类,代表你要执行的具体任务。然后,创建一个`org.quartz.Trigger`实例,其中包含cron表达式,如 `@Scheduled(cron = "0 0/5 * * * ?")` 表示每五分钟执行一次。 4. **数据绑定**:你可以将cron表达式存储在一个配置文件(如application.properties或application.yml)里,或者数据库表中,使用Spring的`@Value`注解从外部获取表达式。例如: ```properties # application.properties quartz.cron.expression=mydataDrivenCronExpression ``` 然后在配置类中读取并注入到触发器中: ```java @Configuration public class QuartzConfig { @Autowired private Environment env; @Bean(destroyMethod = "stop") public SimpleScheduleBuilder simpleSchedule() { return SimpleScheduleBuilder.simpleSchedule() .withIntervalInMilliseconds(5 * 60 * 1000) // 每5分钟执行 .repeatForever(); // 无限循环 } @Bean public Trigger myTrigger() { String cronExp = env.getProperty("quartz.cron.expression"); CronTrigger trigger = (CronTrigger) TriggerBuilder.newTrigger() .withIdentity("myTrigger", "defaultGroup") .usingJobData("cronExpression", cronExp) .forJob(myJob()) .build(); return trigger; } @Bean(name = "myJob") public MyJob myJob() { return new MyJob(); } } ``` 5. **执行任务**:`MyJob`类需要实现`Job`接口,并覆盖`execute()`方法,这里就是实际执行的任务代码。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值