Java 线程池线程数量确定思路


Java线程池线程数量确定思路

参考:https://www.cnblogs.com/xuzhujack/p/10958006.html

多线程可以快速执行任务的原理

因为服务器是拥有多个处理器核心的。运行某进程时,如果只有一个线程,则只能调动一个处理器核心,其他处理器核心可能处于空闲状态。如果是多线程,则可以调用多个处理器核心,用最大效率去处理任务。

创建线程池需要的参数

  • 创建线程池一般需要参数有:核心线程数,最大线程数,线程销毁时间,任务队列,拒绝策略等。
  • 线程池里的线程分为两种,分别是核心线程和非核心线程。当线程池接收到任务时,会先创建核心线程数去处理任务,直至待处理的任务数量超过任务队列长度和核心线程数之和时,会继续创建非核心线程直至最大线程数。
  • 线程池接收到的任务数量在即将超过任务队列长度和最大线程数之和时,会触发拒绝策略处理该任务。
  • 非核心线程在执行完成后会立即销毁,核心线程则会等待设置的销毁时间后再进行销毁。
  • 当任务队列长度足够大时,核心线程数和最大线程数相等,不然不能触发到创建非核心线程

确定线程数

  • 线程数计算公式为:

    Nthreads=NcpuUcpu(1+w/c) =Ncpu*(1+w/c)。

    其中 Nthreads:线程数;Ncpu:处理器核心数;Ucpu:处理器的使用百分比;W/C:等待时间与计算时间的比率

  • Ncpu可以通过以下代码获取
    Runtime.getRuntime().availableProcessors()

  • 等待时间与计算时间的比率

    • 针对IO密集型的,阻塞耗时w一般都是计算耗时几倍c,假设阻塞耗时=计算耗时的情况下,Nthreads=Ncpu*(1+1)=2Ncpu。所以这种情况下,考虑2倍的CPU核心数做为线程数
    • 对于计算密集型的,阻塞耗时趋于0,即w/c趋于0,公式Nthreads = Ncpu。
  • 线程数一般是处理器核心数的整数倍。线程数设置过多,在多任务并发情况下,则会影响服务器的整体运行速度;设置过少,则不能最大化应用服务器性能。所以需要根据具体业务来具体调整。


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM