.Net 线程池小结

.Net的各种异步任务都依赖线程池,深入理解线程池更有助于我们对系统的并发控制。

 

参数:

  1. 当前工作线程数可以通过ThreadPool.ThreadCount属性查询。
  2. 线程池关键的是最小线程数,可以通过ThreadPool.GetMinThreads()函数获取,里面有两个指标参数,工作线程数和io线程数。
  3. 默认最小线程数是逻辑CPU个数,可以通过ThreadPool.SetMinThreads()函数修改这个值。

 

管理策略:

最小线程数不是一开始就投放到线程,也是逐步创建的,以工作线程为例:

  1. 当工作线程数未达到最小线程限制时,新任务后会立即创建线程。
  2. 当工作线程数达到最小线程限制时,新任务依然会创建线程,但不是立即,而是每秒钟不超过2个(应该时为了防止任务洪峰),没来得及执行的任务会排队。
  3. 当任务执行完成,线程池有富裕时,线程池会被逐步回收掉。

 

实践:

对于Web程序来说,如果系统本身有一大堆依赖着线程池的后台任务时,默认的最小线程池就不大够了。

默认的最小线程阈值是cpu个数,是很容易被消耗光的。此时再来web请求时需要再线程池新建线程,由于新的请求的创建线程数不超过每秒2个,很容易导致任务得不到线程池的调度而排队。

 

相关文章:

上一篇:在RestHighLevelClient中增加用户名密码验证


下一篇:elasticsearch笔记(3) java操作es的index