当前位置: 首页 > news >正文

51.线程池大小

问题

1.线程池太小会导致程序不能充分利用系统资源、容易导致饥饿。

2.线程池过大导致更多的线程上下文切换,占用更多的内存。

情况一:CPU密集型运算

应用程序是做一些数据分析,需要大量的使用cpu,程序代码全部都是跟cpu相关的,线程数量 = cpu的核数 + 1, 能够实现最优的cpu利用率。

情况二:I/O密集型运算

CPU不能总是处于繁忙状态,例如当执行业务计算时,这时候会使用cpu资源。但执行I/O操作时,远程RPC调用时,数据库操作时,cpu就闲下来了。可以利用多线程提高它的利用率。

公式:线程数 = 核数 * 期望CPU利用率  *  总时间(cpu计算时间+等待时间) / cpu计算时间

例如:4核cpu计算时间是50%,其他等待时间是50%,期望cpu被100%利用

           4 * 100% * 100% / 50% = 8

http://www.lryc.cn/news/366893.html

相关文章:

  • Python | 开房门(map)
  • MATLAB 函数 function
  • 基于阿里云服务网格流量泳道的全链路流量管理(三):无侵入式的宽松模式泳道
  • 9行超强代码用Python工具快速获取放假日期
  • Elastic Search(ES)Java 入门实操(2)搜索代码
  • Hudi Spark Sql Procedures 回滚 Hudi 表数据
  • 【重学C语言】十九、SDL2 图形化编程的使用
  • 什么是电风扇行情?
  • pytho入门教程
  • Elasticsearch:ES|QL 查询 TypeScript 类型(二)
  • 元音 (音标) 和元音字母的区别
  • SMS - 基于阿里云实现手机短信验证码登录(无需备案,非测试)
  • 使用Python编写Ping监测程序
  • iptables常用命令总结
  • spring 自定义注解实现
  • 10.dockerfile自动构建镜像
  • python -- series和 DataFrame增删改数据
  • window.clearInterval(timer) 清除定时器
  • Java项目如何外发告警日志到企业微信
  • NLP--关键词
  • Qt5学习笔记
  • 数据结构与算法笔记:基础篇 - 散列表(下):为什么散列表和链表经常会一起使用?
  • 读AI未来进行式笔记06自动驾驶技术
  • SpringAOP 常见应用场景
  • html+css示例
  • Day51 动态规划part10+Day52 动态规划part11
  • Wireshark自定义Lua插件
  • 商城项目【尚品汇】07分布式锁-2 Redisson篇
  • Adobe Illustrator 矢量图设计软件下载安装,Illustrator 轻松创建各种矢量图形
  • Nvidia/算能 +FPGA+AI大算力边缘计算盒子:中国舰船研究院