前言

springboot设置定时任务三种常见方式,分别为:

  1. 基于@Scheduled注解。
  2. 基于Quartz框架
  3. 基于xxljob框架。

下面将分别阐述下这三种方式实现方式优缺点

1. @Scheduled

介绍

@Scheduled注解是Spring Framework提供的一个非常简单创建定时任务的方法,将注解添加在方法。Spring Boot自动配置一个任务调度器来执行这些方法。

需要在Spring Boot应用主类配置类上添加@EnableScheduling注解来启用定时任务自动配置。然后,你可以在任何Spring管理bean使用@Scheduled注解来声明定时任务

代码实现
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;

@Component
public class ScheduledTasks {

    @Scheduled(fixedRate = 5000)
    public void taskWithFixedRate() {
        // 任务逻辑
    }

    @Scheduled(cron = "0 * * * * ?")
    public void taskWithCronExpression() {
        // 任务逻辑
    }
}

@Scheduled(fixedRate = 5000)taskWithFixedRate()方法每5秒执行一次

@Scheduled(cron = "0 * * * * ?")taskWithCronExpression()方法根据cron表达式执行。

优点
缺点

2. 基于Quartz框架

介绍

Quartz是一个开源的作业调度库,可以集成到几乎任何Java应用程序中。它提供了丰富的调度选项,包括一次性执行、按照固定间隔重复执行以及基于日历的作业调度。

代码实现
导入依赖
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-quartz</artifactId>
                <version>${spring.version}</version>
            </dependency>
写任务逻辑
package com.account.job;

import org.quartz.Job;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;
import org.springframework.stereotype.Component;

/**
 * @author Hao
 * @date 2023-11-06 17:00
 */
@Component
public class UsernameJob implements Job {

    @Override
    public void execute(JobExecutionContext jobExecutionContext) throws JobExecutionException {
        // 任务逻辑
    }
}
配置定时器
package com.account.config;

import com.account.job.UsernameJob;
import org.quartz.*;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

/**
 * @author Hao
 * @date 2023-11-06 14:58
 */
@Configuration
public class UsernameQuartzConfig {
    @Bean
    public JobDetail userLogJob() {
        return JobBuilder.newJob(UsernameJob.class)
                .storeDurably(true)
                .build();
    }

    @Bean
    public Trigger usernameJobTrigger() {
        return TriggerBuilder.newTrigger()
                .forJob(userLogJob())
                .withSchedule(CronScheduleBuilder.cronSchedule("0 30 * * * ?")) //每30分钟执行一次
                .build();
    }
}

优点
缺点

3. 基于xxl-job框架

介绍

xxl-job是一个分布式任务调度平台,其核心设计目标开发简单、易扩展分布式任务调度解决方案xxl-job在企业级别的分布式任务调度场景中非常受欢迎。

代码实现
搭建linux服务搭建教程
导入依赖
        <xxl-job.version>2.3.1</xxl-job.version>
            <dependency>
                <groupId>com.xuxueli</groupId>
                <artifactId>xxl-job-core</artifactId>
                <version>${xxl-job.version}</version>
            </dependency>
yml配置文件
#XXL-job配置
xxl:
  job:
    admin:
      addresses: http://192.168.133.100:9898/xxl-job-admin
    accessToken: default_token
    executor:
      # 执行器AppName [选填]:执行器心跳注册分组依据;为空关闭自动注册
      appname: xxl-job-executor-sample
      # 执行器端口号 [选填]:小于等于0则自动获取默认端口为9999,单机部署多个执行器时,注意要配置不同执行器端口
      port: 9998

配置类
package com.replication.config;

import com.xxl.job.core.executor.impl.XxlJobSpringExecutor;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

/**
 * @author Hao
 * @date 2023-12-04 11:07
 */
@Configuration
public class XxlJobConfig {
    @Value("${xxl.job.admin.addresses}")
    private String adminAddresses;

    @Value("${xxl.job.accessToken}")
    private String accessToken;

    @Value("${xxl.job.executor.appname}")
    private String appName;

    @Value("${xxl.job.executor.port}")
    private int port;

    @Bean
    public XxlJobSpringExecutor xxlJobSpringExecutor() {
        XxlJobSpringExecutor xxlJobSpringExecutor = new XxlJobSpringExecutor();
        xxlJobSpringExecutor.setAdminAddresses(adminAddresses);
        xxlJobSpringExecutor.setAccessToken(accessToken);
        xxlJobSpringExecutor.setAppname(appName);
        xxlJobSpringExecutor.setPort(port);

        return xxlJobSpringExecutor;
    }
}
注解使用
@XxlJob("helloXxl")
public void xxlJob() {
    log.debug("xxlJob运行当前时间:{}", LocalDateTime.now());
}
优点
缺点

总结

选择定时任务框架时,你应该根据你的应用场景需求来决定。如果你的应用简单,不需要分布式调度和任务持久化,那么@Scheduled注解可能是最简单的选择。如果你需要更复杂的调度功能,或者你的应用是分布式的,那么Quartz或xxl-job可能更适合。xxl-job特别适合于需要集中管理和监控任务的大型分布式系统

原文地址:https://blog.csdn.net/treadsangerbraes/article/details/134792575

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_39810.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注