0

0

SpringBoot的定时任务

絕刀狂花

絕刀狂花

发布时间:2025-07-15 08:26:13

|

765人浏览过

|

来源于php中文网

原创

大家好,我是你们的老朋友全栈君。我们又见面了。

一、基于注解(@Scheduled)的定时任务

使用SpringBoot的@Scheduled注解来创建定时任务非常简单,只需几行代码就能实现。然而,@Scheduled默认是单线程运行,这意味着当启动多个任务时,一个任务的执行时间可能会影响到下一个任务的执行时间。

1、创建定时器

使用SpringBoot和基于注解的方法来创建一个简单的定时任务,只需如下代码:

@Component
@Configuration      // 1.主要用于标记配置类,兼备Component的效果。
@EnableScheduling   // 2.开启定时任务
public class SaticScheduleTask {
    // 3.添加定时任务
    @Scheduled(cron = "0/5 * * * * ?")
    // 或者直接指定时间间隔,例如:5秒
    //@Scheduled(fixedRate=5000)
    private void configureTasks() {
        System.err.println("执行静态定时任务时间: " + LocalDateTime.now());
    }
}

Cron表达式参数的含义如下:

  • 秒(0~59):例如0/5表示每5秒
  • 分(0~59)
  • 时(0~23)
  • 日(0~31):指定某一天,需要计算
  • 月(0~11)
  • 周几(可填1-7 或 SUN/MON/TUE/WED/THU/FRI/SAT)

@Scheduled注解除了支持Cron表达式,还支持简单的延时操作,例如使用fixedDelay或fixedRate,并指定相应的毫秒数。

2、启动测试

启动应用后,您将在控制台看到如下信息:

SpringBoot的定时任务

显然,使用@Scheduled注解非常方便,但有一个缺点:当我们调整执行周期时,需要重启应用才能生效,这多少有些不便。为了实现实时生效的效果,可以考虑使用基于接口的方法来完成定时任务。

二、基于接口(SchedulingConfigurer)的定时任务

大家可能对基于注解的定时任务已经很熟悉了,但在实际应用中,我们常常希望从数据库中动态读取执行时间来执行定时任务,这时候基于接口的定时任务就显得非常有用。

1、导入依赖包:


    org.springframework.boot
    spring-boot-starter
    2.0.4.RELEASE


    
        org.springframework.boot
        spring-boot-starter-web
    
    
        mysql
        mysql-connector-java
    
    
        org.mybatis.spring.boot
        mybatis-spring-boot-starter
        1.3.1
    
    
        org.mybatis
        mybatis
        3.4.5
        compile
    

2、添加数据库记录:

启动本地MySQL数据库,在查询窗口中执行以下脚本:

DROP DATABASE IF EXISTS `socks`;
CREATE DATABASE `socks`;
USE `SOCKS`;
DROP TABLE IF EXISTS `cron`;
CREATE TABLE `cron`  (
  `cron_id` varchar(30) NOT NULL PRIMARY KEY,
  `cron` varchar(30) NOT NULL
);
INSERT INTO `cron` VALUES ('1', '0/5 * * * * ?');

SpringBoot的定时任务

然后在项目的application.yml文件中添加数据源配置:

spring:
  datasource:
    url: jdbc:mysql://localhost:3306/socks
    username: root
    password: 123456

3、创建定时器

准备好数据库数据后,我们可以编写定时任务。注意,这里我们使用TriggerTask来循环读取数据库中设置的执行周期,并执行相关的定时任务。具体代码如下:

@Component
@Configuration      // 1.主要用于标记配置类,兼备Component的效果。
@EnableScheduling   // 2.开启定时任务
public class DynamicScheduleTask implements SchedulingConfigurer {
    @Mapper
    public interface CronMapper {
        @Select("select cron from cron limit 1")
        public String getCron();
    }
@Autowired      // 注入mapper
@SuppressWarnings("all")
CronMapper cronMapper;

/**
 * 执行定时任务.
 */
@Override
public void configureTasks(ScheduledTaskRegistrar taskRegistrar) {
    taskRegistrar.addTriggerTask(
        // 1.添加任务内容(Runnable)
        () -youjiankuohaophpcn System.out.println("执行动态定时任务: " + LocalDateTime.now().toLocalTime()),
        // 2.设置执行周期(Trigger)
        triggerContext -youjiankuohaophpcn {
            // 2.1 从数据库获取执行周期
            String cron = cronMapper.getCron();
            // 2.2 合法性校验.
            if (StringUtils.isEmpty(cron)) {
                // Omitted Code ..
            }
            // 2.3 返回执行周期(Date)
            return new CronTrigger(cron).nextExecutionTime(triggerContext);
        }
    );
}

}

js定时任务插件
js定时任务插件

js定时任务插件

下载

4、启动测试

启动应用后,查看控制台,打印时间符合我们预期的每10秒一次:

SpringBoot的定时任务

然后使用Navicat将执行周期修改为每6秒执行一次,如下图所示:

SpringBoot的定时任务

查看控制台,发现执行周期已经改变,并且无需重启应用,非常方便。如下图所示:

SpringBoot的定时任务

注意:如果在数据库修改时格式出现错误,定时任务会停止,即使重新修改正确也需要重新启动项目才能恢复。

三、基于注解设定多线程定时任务

基于注解设定多线程定时任务

1、创建多线程定时任务

//@Component注解用于对那些比较中立的类进行注释;
//相对与在持久层、业务层和控制层分别采用 @Repository、@Service 和 @Controller 对分层中的类进行注释
@Component
@EnableScheduling   // 1.开启定时任务
@EnableAsync        // 2.开启多线程
public class MultithreadScheduleTask {
@Async
@Scheduled(fixedDelay = 1000)  //间隔1秒
public void first() throws InterruptedException {
System.out.println("第一个定时任务开始 : " + LocalDateTime.now().toLocalTime() + "\r\n线程 : " + Thread.currentThread().getName());
System.out.println();
Thread.sleep(1000 * 10);
}

@Async
@Scheduled(fixedDelay = 2000)
public void second() {
    System.out.println("第二个定时任务开始 : " + LocalDateTime.now().toLocalTime() + "\r\n线程 : " + Thread.currentThread().getName());
    System.out.println();
}

}

注:这里的@Async注解非常关键。

2、启动测试

启动应用后,查看控制台:

SpringBoot的定时任务

从控制台可以看出,第一个定时任务和第二个定时任务互不影响;

并且,由于开启了多线程,第一个任务的执行时间也不受其本身执行时间的限制,所以需要注意可能会出现重复操作导致数据异常。

发布者:全栈程序员栈长,转载请注明出处:https://www.php.cn/link/0aa983d281d1cd5cb3bcc84965830a0e 原文链接:https://www.php.cn/link/c8377ad2a50fb65de28b11cfc628d75c

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

653

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

244

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

280

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

513

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

250

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

384

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

523

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

594

2023.08.14

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

7

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 6.3万人学习

Git 教程
Git 教程

共21课时 | 2.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号