java excel导出2007_java导出1000个07版本的excel,时间过长该如何优化?

将1000个excel拆分为10个任务,每个任务处理100个excel,使用线程池异步操作,每个任务执行完毕后发个消息或者记录一下,等所有任务执行完毕后,打成zip包,服务器新能好的话 可以拆分成更多任务

@EnableAsync

@Configuration

class TaskPoolConfig {

//线程池

@Bean("taskExecutor")

public Executor taskExecutor() {

ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();

executor.setCorePoolSize(10);

executor.setMaxPoolSize(20);

executor.setQueueCapacity(200);

executor.setKeepAliveSeconds(60);

executor.setThreadNamePrefix("taskExecutor-");

executor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy());

executor.setWaitForTasksToCompleteOnShutdown(true);

executor.setAwaitTerminationSeconds(60);return executor;

}

}

@Component

public class Task {

//线程池异步处理

@Async("taskExecutor")

public void doTask(参数。。。) throws Exception {

你的业务逻辑。。。。。

}

}

public class Tests{@Autowired

private Task task;

@Test

public void test() throws Exception {

task.doTask(参数。。。);

}

}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值