springmvc中线程池(ThreadPoolTaskExecutor)的配置

    先说下使用场景:

    由于业务需要,要从服务器下载约50G文件,首先想到的是多线程,于是自己写了个多线程就开始跑。这样做会有什么问题?

    1.开多少线程合适10个?20个?我自己测了测,下载速度都不理想,应该和机器配置有关。

    2.假如开了20,或者50个,后期切换维护是不是也很花时间?

    所以就用到了线程池,可以让线程池来根据任务动态的管理调度线程。


    实现方式:

    首先是线程池的配置如下:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xsi:schemaLocation="http://www.springframework.org/schema/context
          http://www.springframework.org/schema/context/spring-context-4.0.xsd
          http://www.springframework.org/schema/beans
          http://www.springframework.org/schema/beans/spring-beans-4.0.xsd">

    <!--<context:property-placeholder location="mongo.properties"/>-->
    <bean id="threadPoolTaskExecutor"
        class="org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor">

        <!-- 核心线程数,默认为1 -->
        <property name="corePoolSize" value="10" />
        <!-- 最大线程数,默认为Integer.MAX_VALUE -->
        <property name="maxPoolSize" value="50" />

        <!-- 队列最大长度,一般需要设置值>=notifyScheduledMainExecutor.maxNum;默认为Integer.MAX_VALUE-->
        <property name="queueCapacity" value="1000" />
        <!-- 线程池维护线程所允许的空闲时间,默认为60s -->
        <property name="keepAliveSeconds" value="60" />
        <!-- 线程池对拒绝任务(无线程可用)的处理策略,目前只支持AbortPolicy、CallerRunsPolicy;默认为后者 -->
        <property name="rejectedExecutionHandler">
        <!-- AbortPolicy:直接抛出java.util.concurrent.RejectedExecutionException异常 -->
        <!-- CallerRunsPolicy:主线程直接执行该任务,执行完之后尝试添加下一个任务到线程池中,可以有效降低向线程池内添加任务的速度 -->
        <!-- DiscardOldestPolicy:抛弃旧的任务、暂不支持;会导致被丢弃的任务无法再次被执行 -->
        <!-- DiscardPolicy:抛弃当前任务、暂不支持;会导致被丢弃的任务无法再次被执行 -->
        <bean class="java.util.concurrent.ThreadPoolExecutor$CallerRunsPolicy" />

        </property>
    </bean>
</beans>

       

     接着是单个线程代码的编写,每一个线程要做的工作。

     

public class DownloadThreadUtiil implements Runnable{
    private String url;

    public DownloadThreadUtiil(String url){
        this.url = url;
    }

    @Override
    public void run() {
        Utiil utiil = new Util();
        utiil.downLoadFile(url);
        try {
            Thread.sleep(1000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
}


     最后在主线程中读取线程池配置,执行任务。

        List<String> list = utiil.getfileNames(url);

        ApplicationContext context =  new ClassPathXmlApplicationContext("/config.xml");
        ThreadPoolTaskExecutor taskExecutor =
                (ThreadPoolTaskExecutor)context.getBean("threadPoolTaskExecutor");
        String foldName = "E:/"+"tarFile/";
        utiil.mkFolder(foldName);
        for(int i = 0; i < list.size(); i++){
            DownloadThreadUtiil downloadThread = new DownloadThreadUtiil(url);
            taskExecutor.execute(downloadThread);
        }
        long start = System.currentTimeMillis();
        while (true){
            int count = taskExecutor.getActiveCount();
            System.out.println("Active Threads : " + count);
            try{
                Thread.sleep(1000);
            }catch(InterruptedException e){
                e.printStackTrace();
            }
            if(count==0){
                taskExecutor.shutdown();
                long end = System.currentTimeMillis();
                System.out.println("totalTime:"+(end-start)/1000 +"s");
                break; //所有线程任务执行完
            }
        }



   


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值