黑豹程序员-Spring Task实现定时任务

定时任务

项目中,我们有一个特殊的要求,无需人为去触发,而是自动去触发程序。通常有一定的频率,每天,某时等。

实现的四种方式

1、java自身提供定时任务java.util.Timer类,但太过简单,几乎无人使用;

2、ScheduledExecutorService:也jdk自带的一个类;是基于线程池设计的定时任务类;并发性能佳;

3、Quartz:这是一个功能比较强大的的调度器,可以让你的程序在指定时间执行,也可以按照某一个频度执行,配置起来稍显复杂;

4、Spring Task:Spring3.0以后自带的task,可以将它看成一个轻量级的Quartz,而且使用起来比Quartz简单许多;

5、Elastic-Job的特点在于其弹性化的调度和任务分片机制,可以有效地解决任务并发和分布式的问题。它还提供了丰富的任务类型和插件式扩展,例如Shell、HTTP、Dubbo等,方便开发者们快速构建定时任务。另外,Elastic-Job还具有任务的动态配置和监控功能,可以对任务进行实时的管理和调优。

这里可以看出Elastic-Job最为强大,但也太过繁琐。

本人推荐采用Spring Task,其功能足够用,又和Spring对接,可以直接使用Spring的资源,操作起来最为方便。

Spring Task 代码实现

bash 复制代码
@EnableScheduling
@Component
@Slf4j
public class ScheduleTask {
    @Autowired
    private SuperviseTaskService superviseTaskService;
    @Autowired
    private NoticeService noticeService;


    @Scheduled(cron = "*/5 * * * * ?")  //cron表达式,定义定时任务每隔5秒;*/5 * * * * ?;每天凌晨3点执行一次:0 0 3 * * ?
    private void configureTasks() {

        log.debug("执行定时任务: " + new Date());
    }

}
相关推荐
老青蛙18 小时前
权限系统设计-功能设计
后端
粘豆煮包18 小时前
脑抽研究生Go并发-1-基本并发原语-下-Cond、Once、Map、Pool、Context
后端·go
叫我阿柒啊18 小时前
从Java全栈到Vue3实战:一次真实面试中的技术探索
java·数据库·spring boot·微服务·typescript·vue3·restful
武子康18 小时前
Java-118 深入浅出 MySQL ShardingSphere 分片剖析:SQL 支持范围、限制与优化实践
java·大数据·数据库·分布式·sql·mysql·性能优化
IT_陈寒18 小时前
Vite5.0性能翻倍秘籍:7个极致优化技巧让你的开发体验飞起来!
前端·人工智能·后端
Edward.W18 小时前
用 Go + HTML 实现 OpenHarmony 投屏(hdckit-go + WebSocket + Canvas 实战)
开发语言·后端·golang
努力努力再努力wz18 小时前
【c++进阶系列】:万字详解AVL树(附源码实现)
java·运维·开发语言·c++·redis
爱学习de测试小白18 小时前
13-Java-面向对象-封装和this关键字
java
-哈喽沃德-18 小时前
Date、BigDecimal类型值转换
java
凉、介19 小时前
U-Boot 多 CPU 执行状态引导
java·服务器·前端