黑豹程序员-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());
    }

}
相关推荐
皮皮林55121 分钟前
OpenFeign 首次调用卡 3 秒?八年老开发扒透 5 个坑,实战优化到 100ms!
后端
callJJ1 小时前
Spring Data Redis 两种编程模型详解:同步 vs 响应式
java·spring boot·redis·python·spring
phltxy2 小时前
Spring Cloud 分布式服务部署实战:从 0 到 1 实现微服务上线
spring·spring cloud·微服务
千寻girling2 小时前
《 Git 详细教程 》
前端·后端·面试
wbs_scy2 小时前
Linux线程同步与互斥(三):线程同步深度解析之POSIX 信号量与环形队列生产者消费者模型,从原理到源码彻底吃透
java·开发语言
0xDevNull3 小时前
Linux 中 Nginx 代理 Redis 的详细教程
redis·后端
GetcharZp3 小时前
告别 Nginx 手动配置!这款 Go 语言开发的云原生网关,才是容器化时代的真香神器!
后端
jinanwuhuaguo3 小时前
(第三十三篇)五月的文明奠基:OpenClaw 2026.5.2版本的文明级解读
android·java·开发语言·人工智能·github·拓扑学·openclaw
RuoyiOffice3 小时前
SpringBoot+Vue3 企业考勤如何处理法定假期?节假日方案、调休补班与工作日判断链路拆解
spring boot·后端·vue·anti-design-vue·ruoyioffice·假期·人力
xmjd msup4 小时前
spring security 超详细使用教程(接入springboot、前后端分离)
java·spring boot·spring