从数据库获取值设置@Scheduled cron的值(springboot)

我正在使用,Spring Boot并且在调度cron task数据库中存在的使用值时遇到问题。

目前,我正在从属性文件中读取值,如下所示:

@Scheduled(cron= "${time.export.cron}")
public void performJob() throws Exception {
   // do something
}

这很好用,但是我不想从属性文件中获取值,而是想从数据库表中获取它们。有可能吗?

Vignesh:

您可以在SpringBootApplication主类或任何配置类中添加一个bean来从数据库中获取cron值。示例代码如下:

@Autowired
private CronRepository cronRepo;

@Bean
public int getCronValue()
{
    return cronRepo.findOne("cron").getCronValue();
}

您应该创建一个表并在数据库中提供合适的值。之后,您可以在@Scheduled中提供bean。示例代码如下:

@Scheduled(cron="#{@getCronValue}")
  • 5
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
在Spring Boot中,我们可以使用数据库配置的cron表达式来完成定时任务。具体步骤如下: 1. 首先,在数据库中创建一个表来存储定时任务的相关信息,例如任务名称、cron表达式、任务类名等。 2. 创建一个定时任务服务类,用于从数据库中读取定时任务信息,并根据cron表达式执行相应的任务。 3. 在Spring Boot的配置文件中配置数据源和定时任务相关的属性,例如扫描定时任务的包路径、定时任务线程池大小等。 4. 在启动类中添加@EnableScheduling注解,开启定时任务的支持。 5. 在定时任务类中添加@Scheduled注解,并指定cron表达式,以及要执行的方法。 下面是一个示例代码,用于演示如何使用数据库配置的cron表达式来完成定时任务: <<引用>> @Configuration @EnableScheduling public class ScheduledConfig { @Autowired private DataSource dataSource; @Bean public TaskScheduler taskScheduler() { ThreadPoolTaskScheduler scheduler = new ThreadPoolTaskScheduler(); scheduler.setPoolSize(10); scheduler.setThreadNamePrefix("my-scheduled-task-pool-"); scheduler.setAwaitTerminationSeconds(60); scheduler.setWaitForTasksToCompleteOnShutdown(true); return scheduler; } @Bean public ScheduledTaskRegistrar scheduledTaskRegistrar() { ScheduledTaskRegistrar registrar = new ScheduledTaskRegistrar(); registrar.setTaskScheduler(taskScheduler()); registrar.setScheduler(taskScheduler()); registrar.setDataSource(dataSource); return registrar; } } @Component public class MyScheduledTask { @Scheduled(cron = "${my.task.cron}") public void doTask() { // do something } } 在上面的代码中,我们使用了@EnableScheduling注解来开启定时任务的支持,使用@Scheduled注解来指定cron表达式和要执行的方法。同时,我们还创建了一个ScheduledConfig类,用于配置定时任务线程池和数据源,以及一个ScheduledTaskRegistrar类,用于从数据库中读取定时任务信息并执行相应的任务。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值