博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java线程池配置原则
阅读量:7169 次
发布时间:2019-06-29

本文共 562 字,大约阅读时间需要 1 分钟。

hot3.png

CPU密集orIO密集or混合型

看应用是CPU密集型的还是IO密集型的,还是混合型的。

  • CPU密集CPU密集型的话,一般配置CPU处理器个数+/-1个线程,所谓CPU密集型就是指系统大部分时间是在做程序正常的计算任务,例如数字运算、赋值、分配内存、内存拷贝、循环、查找、排序等,这些处理都需要CPU来完成。

  • IO密集IO密集型的话,是指系统大部分时间在跟I/O交互,而这个时间线程不会占用CPU来处理,即在这个时间范围内,可以由其他线程来使用CPU,因而可以多配置一些线程。

  • 混合型混合型的话,是指两者都占有一定的时间。

估算的经验公式

  • Ncpu=CPU的数量

  • Ucpu=目标CPU使用率

  • W/C=等待时间与计算时间的比率

为保持处理器达到期望的使用率,最优的线程池的大小等于

Nthreads=Ncpu*Ucpu*(1+W/C)

观察线程池统计信息

Java中,可以通过Runtime.getRuntime().availableProcessors()获取可以用的cpu数量。

具体线程池大小观测,可以通过覆盖executor的钩子方法,进行线程池的监控,查看等待队列大小等等,主要观察等待队列的大小以及拒绝的任务多少。

转载于:https://my.oschina.net/u/2269952/blog/844227

你可能感兴趣的文章
jquery把表单数据序列成json,支持多维数组
查看>>
virtualbox mac-debian共享文件夹
查看>>
[转载]当web配置文件 appSettings配置的东西越来越多时,可以拆开了
查看>>
int *i = new int;
查看>>
CCF计算机认证——字符串匹配问题(运行都正确,为什么提交后只给50分?)...
查看>>
POST提交的四种类型
查看>>
DataTable转List<T>
查看>>
安卓项目开发
查看>>
使用C#把发表的时间改为几个月,几天前,几小时前,几分钟前,或几秒前
查看>>
2019-06-11 Java学习日记之Bootstrap
查看>>
解决apache 443端口被占用
查看>>
PHP中PDO错误/异常(PDOException)处理
查看>>
中国科学院大学生创新实践训练计划-
查看>>
洛谷——P1294 高手去散步
查看>>
python正则表达式
查看>>
Blob写入文件
查看>>
Again Stone Game
查看>>
MySQL 5.7.9修改root密码以及新特性
查看>>
HTML5 —— 属性
查看>>
Oracle Alter Table Modify列语句
查看>>