定时任务线程池的使用

1、配置定时任务启动

java 复制代码
@SpringBootApplication
@EnableScheduling
public class Application {

    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }

}

2、具体使用

java 复制代码
import org.springframework.scheduling.TaskScheduler;

@Component
public class TaskServiceImpl extends TaskService {

    // 预设的定时任务名称
    private final Map<String, ScheduledFuture<?>> scheduledJobs = new HashMap<>();

    @Resource
    private TaskScheduler taskScheduler;

    @Override
    public boolean startJob(String key, String croon) {
        log.info("================ ⏹️ 正在启动定时任务{} ================", key);
        try {
            // 校验cron表达式是否有效
            if(!CronExpression.isValidExpression(cron)){
                // todo cron表达式无效处理    
            }
                    
            // 取消已存在的任务
            this.cancelJob(key);

            // 创建新的定时任务
            CronTrigger cronTrigger = new CronTrigger(cron);
            Runnable jobTask = () -> {
                // todo 任务内容
            };
            ScheduledFuture<?> future = taskScheduler.schedule(jobTask, cronTrigger);
            scheduledJobs.put(node.getCode(), future);

            Date nextExecutionTime = cronTrigger.nextExecutionTime(new SimpleTriggerContext());
            log.info("✅ 定时任务 '{}' 已启动,cron表达式: {},下一次执行时间:{}", key, cron, DateUtils.parseDateToStr("yyyy-MM-dd HH:mm:ss", nextExecutionTime));
        } catch (Exception e) {
            log.error("❌ 启动定时任务 '{}' 失败", key);
            return false;
        }
        return true;
    }

    @Override
    public void cancelJob(String key) {
        ScheduledFuture<?> future = scheduledJobs.remove(key);
        if (future != null && !future.isCancelled()) {
            future.cancel(false);
            log.info("⏹️  定时任务 '{}' 已取消", nodeCode);
        }
    }

}

核心执行为

java 复制代码
ScheduledFuture<?> future = taskScheduler.schedule(jobTask, cronTrigger);

TaskScheduler是spring自带的定时任务线程池,可以在指定时间(cron)将预设任务投入线程池中并行执行,该线程池默认线程数为4,应用于需要动态更改时间或者启用关闭的定时任务

相关推荐
ITOM运维行者4 小时前
从零搭建企业级服务器监控体系:踩坑实录与架构设计
前端·后端
用户4099322502124 小时前
Vue状态管理入门第四章:组合式store和SSR风险
前端·vue.js·后端
用户34232323763174 小时前
SPI 通信与高速外设驱动详解
后端
魏祖潇5 小时前
SDD 完整指南——Spec 端打底、Story 端交付、留白区
人工智能·后端
feelmylife595 小时前
消息队列可靠投递与幂等消费 -- 从"消息丢了"到"消息别重复"的完整工程实践
后端
雪隐5 小时前
个人电脑玩AI-10让5060 Ti给你打工——部署 Odysseus:终于有个能打的"AI管家"了
人工智能·后端
copyer_xyf6 小时前
FastAPI 如何连接 MySQL
后端·python
IT_陈寒6 小时前
Vite打包时踩的坑:静态资源为啥突然404了?
前端·人工智能·后端
葫芦和十三7 小时前
图解 MongoDB 25|分片架构三件套:mongos、config server 和 shard
后端·mongodb·agent
葫芦和十三13 小时前
图解 MongoDB 26|片键设计:决定集群命运的一个决定
后端·mongodb·agent