zoukankan      html  css  js  c++  java
  • SpringBoot基于数据库的定时任务实现

    在我们平时开发的项目中,定时任务基本属于必不可少的功能,那大家都是怎么做的呢?但我知道的大多都是静态定时任务实现。

    基于注解来创建定时任务非常简单,只需几行代码便可完成。实现如下:

    @Configuration
    @EnableScheduling
    public class SimpleScheduleTask {
    
        //10秒钟执行一次
        @Scheduled(cron = "0/10 * * * * ?")
        private void tasks() {
            System.out.println("【定时任务】 每10秒执行一次!");
        }
    }

    Cron表达式参数分别表示(从左到右):
    秒(0~59) 如0/5表示每5秒
    分(0~59)
    时(0~23)
    日(0~31) 月的某一天
    月(0~11)
    周几( 可填1-7 或 SUN/MON/TUE/WED/THU/FRI/SAT)

    就上面几行代码,就能搞定一个定时任务。显然,使用Scheduled 确实特别的方便,但有很大的缺点和局限,就是当我们调整了执行计划的时间时,需要重启服务才能生效,这就有些不方便。为了达到实时生效的效果,可以通过数据库来动态实现定时任务。

     

    基于数据库的动态定时任务实现

    将定时任务配置在数据库,启动项目的时候,用mybatis读取数据库,实例化对象,并设定定时任务。如果需要新增,减少,修改定时任务,仅需要修改数据库资料,并重启项目即可,无需改代码。

    数据库配置

     

    运行的结果

     

    这样我们可以通过直接修改数据库,执行周期就会改变,并且不需要我们重启应用,十分方便。

    推荐阅读:

    Java中大量if...else语句的消除替代方案

    Java8中遍历Map的常用四种方式

    推荐一些MySQL优化技巧,效率提升不止十倍!

    扫码关注公众号,发送关键词获取相关资料:
    1. 发“Springboot”领取电商项目实战源码;

    2. 发“SpringCloud”领取学习实战资料;

     
  • 相关阅读:
    Hbase 安装
    Hive操作
    Hive安装
    HDFS操作
    hadoop安装
    番茄时间管理法(Pomodoro Technique)
    测试架构师修炼之道:“秘书九段”的故事
    windows远程连接报:身份错误,函数不支持的解决办法
    Linux crontab配置
    Hadoop 历史服务配置启动查看
  • 原文地址:https://www.cnblogs.com/lyn20141231/p/12105211.html
Copyright © 2011-2022 走看看