在数据库配置定时任务并每次执行后更新

该博客展示了如何在Spring Boot应用中实现定时任务,并通过数据库配置的定时策略执行。`OrderTask`类实现了`SchedulingConfigurer`接口,动态获取数据库中的`order_cancel_window`参数作为Cron表达式来设定任务执行间隔。定时任务`sendTimeCancelOrder`会查询并处理特定状态的数据。

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

在数据库配置定时任务并每次执行后更新

定时任务类实现SchedulingConfigurer,直接上代码

package com.sanxin.cloud.app.api.task;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.sanxin.cloud.common.StaticUtils;
import com.sanxin.cloud.entity.GrabSinglePond;
import com.sanxin.cloud.service.GrabSinglePondService;
import com.sanxin.cloud.service.InfoParamService;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Lazy;
import org.springframework.scheduling.Trigger;
import org.springframework.scheduling.TriggerContext;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.scheduling.annotation.SchedulingConfigurer;
import org.springframework.scheduling.config.CronTask;
import org.springframework.scheduling.config.FixedRateTask;
import org.springframework.scheduling.config.ScheduledTaskRegistrar;
import org.springframework.scheduling.support.CronTrigger;
import org.springframework.stereotype.Component;

import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.util.Date;
import java.util.List;


/**
 * @author zero
 * @version 1.0
 * @date 2020-12-31
 */

@Lazy(value = false)
@Component
public class OrderTask implements SchedulingConfigurer {
	@Autowired
	private GrabSinglePondService grabSinglePondService;
	@Autowired
	private InfoParamService infoParamService;


	private Logger logger = LoggerFactory.getLogger(OrderTask.class);

	/**
	 * 定时发送取消弹窗
	 */
//    @Scheduled(fixedRate = 3000)
	public void sendTimeCancelOrder() {
		List<GrabSinglePond> singlePonds = grabSinglePondService.list(new QueryWrapper<GrabSinglePond>()
				.eq("status", StaticUtils.STATUS_YES));
		System.out.println(singlePonds);
		configureTasks(new ScheduledTaskRegistrar());
		logger.info("定时器重置");//每次执行实现的方法重置
	}

	@Override
	public void configureTasks(ScheduledTaskRegistrar scheduledTaskRegistrar) {
		logger.info("定时任务启动");
		//通过校验的数据执行定时任务
		try {
			scheduledTaskRegistrar.addTriggerTask(getRunnable(), getTrigger());
		} catch (Exception e) {
			logger.error("定时任务启动错误");
		}
		logger.info("定时任务启动完成");
	}

	private Trigger getTrigger() {
		return new Trigger() {
			@Override
			public Date nextExecutionTime(TriggerContext triggerContext) {
				//将Cron 0/1 * * * * ? 输入取得下一次执行的时间
				String orderCancelWindow = infoParamService.getValueByCode("order_cancel_window");//数据库配置的定时策略
				CronTrigger trigger = new CronTrigger(orderCancelWindow);
				Date nextExec = trigger.nextExecutionTime(triggerContext);
				return nextExec;
			}
		};

	}

	private Runnable getRunnable() {
		return new Runnable() {
			@Override
			public void run() {
				try {
					Method method = OrderTask.class.getMethod("sendTimeCancelOrder", null);//如果是当前类直接执行方法,其他类的方法可以通过class或者getBean实现
					method.invoke(OrderTask.this);
				} catch (InvocationTargetException e) {
					logger.error("定时任务启动错误,反射异常:");
				} catch (Exception e) {
					logger.error(e.getMessage());
				}
			}
		};
	}

}
好的,我了解了您的问题。在Spring Cloud集成Quartz时,需要进行以下数据库配置: 1. 首先,在您的Spring Boot项目中添加Quartz的依赖项。您可以在pom.xml文件中添加以下依赖项: ``` <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-quartz</artifactId> </dependency> ``` 2. 接下来,在application.properties文件中配置Quartz的数据库属性,例如: ``` spring.quartz.job-store-type=jdbc spring.quartz.jdbc.initialize-schema=always spring.datasource.url=jdbc:mysql://localhost:3306/quartz spring.datasource.username=root spring.datasource.password=password spring.datasource.driver-class-name=com.mysql.jdbc.Driver ``` 其中,spring.quartz.job-store-type设置为jdbc,表示Quartz将使用数据库存储作业和触发器,spring.quartz.jdbc.initialize-schema设置为always表示每次启动应用程序时都会初始化Quartz数据库spring.datasource.url、spring.datasource.username、spring.datasource.password和spring.datasource.driver-class-name为您的数据库连接属性。 3. 最后,定义您的定时任务,例如: ``` @Configuration public class QuartzConfiguration { @Bean public JobDetail myJobDetail() { return JobBuilder.newJob(MyJob.class) .withIdentity("myJob") .storeDurably() .build(); } @Bean public Trigger myTrigger() { return TriggerBuilder.newTrigger() .forJob(myJobDetail()) .withIdentity("myTrigger") .withSchedule(CronScheduleBuilder.cronSchedule("0/5 * * * * ?")) .build(); } } @Component public class MyJob implements Job { @Override public void execute(JobExecutionContext context) { // 任务逻辑 } } ``` 其中,定时任务使用Cron表达式配置,该表达式将在每分钟的第0秒开始,每5秒执行一次任务。 以上就是Spring Cloud集成Quartz数据库配置定时任务的方法。希望能够帮助到您!
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值