0
点赞
收藏
分享

微信扫一扫

高并发、任务执行时间短的业务怎样使用线程池?并发不高、任务执行时间长的业务怎样使用线程池?并发高、业务执行时间长的业务怎样使用线程池?

Spinach菠菜 2022-03-11 阅读 36

这是我在并发编程网上看到的一个问题,希望每个人都能看到并且思考一下,因为这个问题非常好、非

常实际、非常专业。关于这个问题,个人看法是:

1 高并发、任务执行时间短的业务,线程池线程数可以设置为 CPU 核数 +1 ,减少线程上下文的切换

2 并发不高、任务执行时间长的业务要区分开看:

假如是业务时间长集中在 IO 操作上,也就是 IO 密集型的任务,因为 IO 操作并不占用 CPU ,所以不要

让所有的 CPU 闲下来,可以加大线程池中的线程数目,让 CPU 处理更多的业务

假如是业务时间长集中在计算操作上,也就是计算密集型任务,这个就没办法了,和(

1 )一样

吧,线程池中的线程数设置得少一些,减少线程上下文的切换

3 并发高、业务执行时间长,解决这种类型任务的关键不在于线程池而在于整体架构的设计,看看这些

业务里面某些数据是否能做缓存是第一步,增加服务器是第二步,至于线程池的设置,设置参考(

2 )。

最后,业务执行时间长的问题,也可能需要分析一下,看看能不能使用中间件对任务进行拆分和解耦。

举报

相关推荐

0 条评论