Callable项目实战应用

本文介绍了如何在Java项目中配置和使用Callable,展示了如何创建线程池,包括针对CPU密集型和IO密集型任务的不同配置,并提供了一个异步保存数据的任务示例。
摘要由CSDN通过智能技术生成

Callable项目实战应用

package com.carnation.config;

import org.springframework.boot.autoconfigure.task.TaskExecutionAutoConfiguration;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.scheduling.annotation.AsyncAnnotationBeanPostProcessor;
import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor;

import java.util.concurrent.*;

/**

  • 线程池配置管理

  • @author chj 2021/01/22
    */
    @Configuration
    public class ThreadPoolConfig {

    // 取得本地机器cpu数量
    public final static int THREAD_COUNT = Runtime.getRuntime().availableProcessors();

    /**

    • IO密集型任务
    • 自定义线程池,参数有待调整 (此操作会使默认线程池不初始化 也可使用springboot默认 但参数配置需要修改 添加在yml中即可)
    • springboot Executor 自动装配{@link TaskExecutionAutoConfiguration}
    • 设置核心线程数:
    • CPU密集型:故而大小设置为CPU核心数+1,防止CPU页缺失
    • IO高密集型:任务多为数据库等待执行耗时长,可以适当增加线程数量,例如:CPU*2-1
    • @return
      /
      @Bean(name = {TaskExecutionAutoConfiguration.APPLICATION_TASK_EXECUTOR_BEAN_NAME,
      AsyncAnnotationBeanPostProcessor.DEFAULT_TASK_EXECUTOR_BEAN_NAME})
      public ThreadPoolTaskExecutor taskExecutor() {
      ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
      executor.setCorePoolSize(THREAD_COUNT
      3-1);
      executor.setMaxPoolSize(THREAD_COUNT*4);
      executor.setQueueCapacity(1000);
      executor.setKeepAliveSeconds(300);
      executor.setThreadNamePrefix(“taskExecutor-”);
      executor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy());
      return executor;
      }

    /**

    • CPU密集型 任务

    • @return
      */
      @Bean(“mibIoThreadPoolTask”)
      public Executor mibIoThreadPoolTask() {
      ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();

      executor.setCorePoolSize(THREAD_COUNT+1);
      // 设置最大线程数
      executor.setMaxPoolSize(THREAD_COUNT*2);
      // 设置队列容量
      executor.setQueueCapacity(200);
      // 设置线程活跃时间(

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值