当前位置:网站首页>线程池参数及合理设置
线程池参数及合理设置
2022-07-05 19:38:00 【androidstarjack】
点击上方关注 “终端研发部”
设为“星标”,和你一起掌握更多数据库知识一、线程池的7大核心参数
1. corePoolSize
核心线程数目核心线程会一直存活,及时没有任务需要执行,当线程数小于核心线程数时,即使有线程空闲,线程池也会优先创建新线程处理当设置allowCoreThreadTimeout=true(默认false)时,核心线程会超时关闭
2. maximumPoolSize 最大线程数目
当空闲线程时间达到 keepAliveTime,线程会关闭,直到数量等于corePoolSize
3. keepAliveTime空闲时间
4. unit 时间单位
超过核心线程的生存时间单位,如秒、毫秒等。
5. workQueue 阻塞队列
LinkedBlockingQueue:无界队列,容量Integer.MAX_VALUE,(FixedThreadPool 和 SingleThreadExecutor 线程池的线程数是固定的,用的就是LinkedBlockingQueue)
SynchronousQueue:直接提交的任务队列(CachedThreadPool 的最大线程数是 Integer.MAX_VALUE,用的是SynchronousQueue)
ArrayBlockingQueue:指定队列大小(corePoolSize >队列>maximumPoolSize )
6. threadFactory 线程工厂
可以定制线程对象的创建,例如设置线程名字、是否是守护线程等。
7. handler 拒绝策略
AbortPolicy:终止策略。超过最大承载、执行拒绝任务时,会直接抛出一个类型为RejectedExecutionException 的 RuntimeException异常
CallerRunsPolicy:调用者执行策略。超过承载,执行策略时,调用者线程执行任务。
DiscardOldestPolicy:丢弃最早任务策略。超过承载,丢弃队列中最早的任务。若线程池关闭,则舍弃。
DiscardPolicy:丢弃策略。超过承载,丢弃任务。
实现RejectedExecutionHandler接口,自定义策略
二、线程池参数的合理设置
Ø tasks,程序每秒需要处理的最大任务数量
Ø tasktime,单线程处理一个任务所需要的时间
Ø responsetime,系统允许任务最大的响应时间
corePoolSize
每个任务需要tasktime秒处理,则每个线程每秒可处理1/tasktime个任务。系统每秒有tasks个任务需要处理,则需要的线程数为:tasks/(1/tasktime)。即tasks*tasktime个线程数。具体数字最好根据8020原则,即80%情况下系统每秒任务数。
queueCapacity:任务队列的长度
任务队列的长度要根据核心线程数,以及系统对任务响应时间的要求有关。队列长度可以设置为(corePoolSize/tasktime)responsetime
maxPoolSize:最大线程数
当系统负载达到最大值时,核心线程数已无法按时处理完所有任务,这时就需要增加线程。每秒200个任务需要20个线程,那么当每秒达到1000个任务时,则需要(1000-queueCapacity)*(20/200)。
keepAliveTime
keepAliveTiime设定值可根据任务峰值持续时间来设定。
以上关于线程数量的计算并没有考虑CPU的情况。若结合CPU的情况,比如,当线程数量达到50时,CPU达到100%,则将maxPoolSize设置为60也不合适,此时若系统负载长时间维持在每秒1000个任务,则超出线程池处理能力,应设法降低每个任务的处理时间(tasktime)。
写在最后的话
大家看完有什么不懂的可以在下方留言讨论,也可以私信问我一般看到后我都会回复的。最后觉得文章对你有帮助的话记得点个赞哦,点点关注不迷路
@终端研发部
每天都有新鲜的干货分享!
回复 【idea激活】即可获得idea的激活方式
回复 【Java】获取java相关的视频教程和资料
回复 【SpringCloud】获取SpringCloud相关多的学习资料
回复 【python】获取全套0基础Python知识手册
回复 【2020】获取2020java相关面试题教程
回复 【加群】即可加入终端研发部相关的技术交流群
阅读更多
用 Spring 的 BeanUtils 前,建议你先了解这几个坑!
lazy-mock ,一个生成后端模拟数据的懒人工具
在华为鸿蒙 OS 上尝鲜,我的第一个“hello world”,起飞!
字节跳动一面:i++ 是线程安全的吗?
一条 SQL 引发的事故,同事直接被开除!!
太扎心!排查阿里云 ECS 的 CPU 居然达100%
一款vue编写的功能强大的swagger-ui,有点秀(附开源地址)
相信自己,没有做不到的,只有想不到的在这里获得的不仅仅是技术!
喜欢就给个“在看”边栏推荐
- MySql中的longtext字段的返回问题及解决
- 微波雷达感应模块技术,实时智能检测人体存在,静止微小动静感知
- How MySQL queries and modifies JSON data
- IFD-x 微型红外成像仪(模块)关于温度测量和成像精度的关系
- 国海证券在网上开户安全吗?
- C application interface development foundation - form control (5) - grouping control
- Realizing deep learning framework from zero -- LSTM from theory to practice [practice]
- 测试外包公司怎么样?
- 手机开户选择哪家券商公司比较好哪家平台更安全
- 面试官:Redis中集合数据类型的内部实现方式是什么?
猜你喜欢

司空见惯 - 英雄扫雷鼠

力扣 729. 我的日程安排表 I

What is the core value of testing?

微波雷达感应模块技术,实时智能检测人体存在,静止微小动静感知

JMeter 常用的几种断言方法,你会了吗?

S7-200SMART利用V90 MODBUS通信控制库控制V90伺服的具体方法和步骤

Force buckle 1200 Minimum absolute difference
![[OBS] qstring's UTF-8 Chinese conversion to blog printing UTF-8 char*](/img/cc/172684664a9115943d45b0646ef110.png)
[OBS] qstring's UTF-8 Chinese conversion to blog printing UTF-8 char*

What does software testing do? What are the requirements for learning?

Force buckle 729 My schedule I
随机推荐
What are the reliable domestic low code development platforms?
集合
信息/数据
安信证券在网上开户安全吗?
aggregate
5 years of experience, 27 days of Android programmer interview, 2022 programmer advanced classic
Common - Hero Minesweeper
Mysql如何对json数据进行查询及修改
[AI framework basic technology] automatic derivation mechanism (autograd)
Microwave radar induction module technology, real-time intelligent detection of human existence, static micro motion and static perception
Inventory of the most complete low code / no code platforms in the whole network: Jiandao cloud, partner cloud, Mingdao cloud, Qingliu, xurong cloud, Jijian cloud, treelab, nailing · Yida, Tencent clo
再忙不能忘安全
That's awesome. It's enough to read this article
【AI 框架基础技术】自动求导机制 (Autograd)
手机股票开户安全吗?靠不靠谱啊?
众昂矿业:2022年全球萤石行业市场供给现状分析
2022 the latest big company Android interview real problem analysis, Android development will be able to technology
redis集群模拟消息队列
Zhongang Mining: analysis of the current market supply situation of the global fluorite industry in 2022
How to choose the notion productivity tools? Comparison and evaluation of notion, flowus and WOLAI