ThreadPoolTaskScheduler spring定时任务框架,线程池配置

参数配置,只能配置核心线程池参数大小

@Bean(name = "threadPoolTaskScheduler")
    public ThreadPoolTaskScheduler taskScheduler() {
        // Spring 默认配置是核心线程数大小为1,最大线程容量大小不受限制,队列容量也不受限制。
        ThreadPoolTaskScheduler scheduler = new ThreadPoolTaskScheduler();
        // 核心线程数
        scheduler.setPoolSize(config.getCoreSize());
        //executor.setCorePoolSize(config.getCoreSize());
        // 最大线程数
        //executor.setMaxPoolSize(config.getMaxSize());
        // 队列大小
        //executor.setQueueCapacity(config.getQueueCapacity());
        // 当最大池已满时,此策略保证不会丢失任务请求,但是可能会影响应用程序整体性能。
        //new ThreadPoolExecutor.AbortPolicy()
        scheduler.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy());
        scheduler.setThreadNamePrefix(config.getThreadNamePrefix());
        //表明是否等待所有线程执行完任务
        scheduler.setWaitForTasksToCompleteOnShutdown(true);
        //等待的时间,超过这个时间就强制销毁,因为不能无限的等待下去以确保应用最后能够被关闭
        scheduler.setAwaitTerminationSeconds(600);
        scheduler.setRemoveOnCancelPolicy(Boolean.TRUE);
        scheduler.setErrorHandler((throwable) ->{
            logger.error("====" + throwable.getMessage() + "====", throwable);
        });
        scheduler.initialize();
        return scheduler;
    }
   
​
public void initialize() {
        if (logger.isInfoEnabled()) {
            logger.info("Initializing ExecutorService" + (this.beanName != null ? " '" + this.beanName + "'" : ""));
        }
        if (!this.threadNamePrefixSet && this.beanName != null) {
            setThreadNamePrefix(this.beanName + "-");
        }
        this.executor = initializeExecutor(this.threadFactory, this.rejectedExecutionHandler);
    }
@Override
    protected ExecutorService initializeExecutor(
            ThreadFactory threadFactory, RejectedExecutionHandler rejectedExecutionHandler) {
​
        this.scheduledExecutor = createExecutor(this.poolSize, threadFactory, rejectedExecutionHandler);
​
        if (this.removeOnCancelPolicy) {
            if (this.scheduledExecutor instanceof ScheduledThreadPoolExecutor) {
                ((ScheduledThreadPoolExecutor) this.scheduledExecutor).setRemoveOnCancelPolicy(true);
            }
            else {
                logger.debug("Could not apply remove-on-cancel policy - not a ScheduledThreadPoolExecutor");
            }
        }
​
        return this.scheduledExecutor;
    }
ThreadPoolTaskScheduler中创建
@Override
    protected ExecutorService initializeExecutor(
            ThreadFactory threadFactory, RejectedExecutionHandler rejectedExecutionHandler) {
​
        this.scheduledExecutor = createExecutor(this.poolSize, threadFactory, rejectedExecutionHandler);
​
        if (this.removeOnCancelPolicy) {
            if (this.scheduledExecutor instanceof ScheduledThreadPoolExecutor) {
                ((ScheduledThreadPoolExecutor) this.scheduledExecutor).setRemoveOnCancelPolicy(true);
            }
            else {
                logger.debug("Could not apply remove-on-cancel policy - not a ScheduledThreadPoolExecutor");
            }
        }
​
        return this.scheduledExecutor;
    }

protected ScheduledExecutorService createExecutor(
            int poolSize, ThreadFactory threadFactory, RejectedExecutionHandler rejectedExecutionHandler) {
​
        return new ScheduledThreadPoolExecutor(poolSize, threadFactory, rejectedExecutionHandler);
    }

ScheduledThreadPoolExecutor中创建

 public ScheduledThreadPoolExecutor(int corePoolSize,
                                       ThreadFactory threadFactory,
                                       RejectedExecutionHandler handler) {
        super(corePoolSize, Integer.MAX_VALUE, 0, NANOSECONDS,
              new DelayedWorkQueue(), threadFactory, handler);
    }
​
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ThreadPoolTaskSchedulerSpring 框架中提供的一个线程池定时任务调度器,可以在预定的时间间隔或固定的时间执行任务。它可以用于执行异步任务,如发送邮件或者短信,定时从数据库或者第三方接口获取数据等。 ThreadPoolTaskScheduler 可以通过配置线程池的大小来控制并发执行任务的数量,从而避免系统资源浪费。它也提供了一些方法来控制定时任务的执行,如取消任务、暂停任务、恢复任务等。 下面是一个使用 ThreadPoolTaskScheduler 调度定时任务的示例: 首先,需要在 Spring 配置文件中配置 ThreadPoolTaskScheduler定时任务: ```xml <bean id="taskScheduler" class="org.springframework.scheduling.concurrent.ThreadPoolTaskScheduler"> <property name="poolSize" value="5"/> </bean> <bean id="myTask" class="com.example.MyTask"/> <task:scheduled-tasks> <task:scheduled ref="myTask" method="run" fixed-delay="5000"/> </task:scheduled-tasks> ``` 其中,taskScheduler 配置线程池大小为 5,myTask 是一个实现了 Runnable 接口的类,run 方法是定时任务要执行的方法,fixed-delay 属性表示每隔 5 秒执行一次。 接着,在 MyTask 类中实现 run 方法: ```java public class MyTask implements Runnable { @Override public void run() { // 执行定时任务的逻辑 System.out.println("定时任务执行了!"); } } ``` 这样就可以使用 ThreadPoolTaskScheduler 定时执行 MyTask 中的 run 方法了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值