【Java】线程池配置
先看JUC包自带的一个资源 线程池执行器:
初始化参数如下
ThreadPoolExecutor threadPoolExecutor = new ThreadPoolExecutor(
corePoolSize, // 核心线程数量
maximumPoolSize, // 峰值线程数量
keepAliveTime, // 保留时限,当线程数量超出峰值数量时,保留多久后释放多余的线程资源
timeUnit, // 时限单位
synchronousQueue, // 工作队列,存放需要提交给执行器执行的任务
threadFactory, // 线程工厂
callerRunsPolicy // 任务拒绝执行处理器(拒绝策略)
);
基础参数配置:
峰值上限,保留时限,根据实际业务情况来设置
/**
* 线程数量参数 计算公式参考
* https://www.cnblogs.com/warehouse/p/10810338.html
*/
int cpuCount = Runtime.getRuntime().availableProcessors(); int corePoolSize = 2 * cpuCount; // 核心线程数量(初始化和空闲存留时的线程数量)
int maximumPoolSize = 100; // 最大线程数量 线程占用峰值上限数量
long keepAliveTime = 100; // 保留时长(当前线程数量大于核心数量时保留多久后释放多余线程)
TimeUnit timeUnit = TimeUnit.SECONDS; // 保留时长单位
几种工作队列:
/**
* SynchronousQueue队列
* SynchronousQueue是一个特殊的BlockingQueue
* 它没有容量,每执行一个插入操作就会阻塞,需要再执行一个删除操作才会被唤醒
* 反之每一个删除操作也都要等待对应的插入操作。
*/
SynchronousQueue<Runnable> synchronousQueue = new SynchronousQueue<>(); /**
* ArrayBlockingQueue有界任务队列,若有新的任务需要执行时,线程池会创建新的线程,
* 直到创建的线程数量达到corePoolSize时,则会将新的任务加入到等待队列中。
* 若等待队列已满,即超过ArrayBlockingQueue初始化的容量,则继续创建线程,直到线程数量达到maximumPoolSize设置的最大线程数量,
* 若大于maximumPoolSize,则执行拒绝策略。在这种情况下,线程数量的上限与有界任务队列的状态有直接关系,
* 如果有界队列初始容量较大或者没有达到超负荷的状态,线程数将一直维持在corePoolSize以下,
* 反之当任务队列已满时,则会以maximumPoolSize为最大线程数上限。
*/
ArrayBlockingQueue<Runnable> arrayBlockingQueue = new ArrayBlockingQueue<>(10); /**
* 无界任务队列,线程池的任务队列可以无限制的添加新的任务,
* 而线程池创建的最大线程数量就是你corePoolSize设置的数量,
* 也就是说在这种情况下maximumPoolSize这个参数是无效的,
* 哪怕你的任务队列中缓存了很多未执行的任务,当线程池的线程数达到corePoolSize后,就不会再增加了;\
* 若后续有新的任务加入,则直接进入队列等待,
* 当使用这种任务队列模式时,一定要注意你任务提交与处理之间的协调与控制,
* 不然会出现队列中的任务由于无法及时处理导致一直增长,直到最后资源耗尽的问题。
*/
LinkedBlockingQueue<Runnable> linkedBlockingQueue = new LinkedBlockingQueue<>(); /**
* PriorityBlockingQueue它其实是一个特殊的无界队列,它其中无论添加了多少个任务,线程池创建的线程数也不会超过corePoolSize的数量
* ,只不过其他队列一般是按照先进先出的规则处理任务,而PriorityBlockingQueue队列可以自定义规则根据任务的优先级顺序先后执行。
*/
PriorityBlockingQueue<Runnable> priorityBlockingQueue = new PriorityBlockingQueue<>();
线程工厂使用默认工厂提供:
/**
* ThreadFactory
*/
ThreadFactory threadFactory = Executors.defaultThreadFactory();
拒绝策略一般使用第4个,谁提交谁执行:
/**
* 当线程需求数量超出预设峰值上限,如何拒绝线程资源获取
* 1、直接丢弃
* 2、替换工作队列的最后一个
* 3、抛异常中断
* 4、哪个线程提交的任务就让那个线程执行
* 5、自定义
*/
ThreadPoolExecutor.DiscardPolicy discardPolicy = new ThreadPoolExecutor.DiscardPolicy();
ThreadPoolExecutor.DiscardOldestPolicy discardOldestPolicy = new ThreadPoolExecutor.DiscardOldestPolicy();
ThreadPoolExecutor.AbortPolicy abortPolicy = new ThreadPoolExecutor.AbortPolicy();
ThreadPoolExecutor.CallerRunsPolicy callerRunsPolicy = new ThreadPoolExecutor.CallerRunsPolicy();
RejectedExecutionHandler handler = (r, executor) -> {
// 入参一个runnable 和 executor
};
Spring封装的线程池:
任务执行器
1、不需要设置队列类型,但是要提供队列长度
2、可以设置线程名称前缀
3、当所有任务执行完毕时,释放线程池资源
4、需要调用初始化方法
ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
executor.setCorePoolSize(corePoolSize);
executor.setMaxPoolSize(maximumPoolSize);
executor.setQueueCapacity((int)(maximumPoolSize * 1.5D));
executor.setKeepAliveSeconds(60);
executor.setThreadNamePrefix("线程名称前缀");
executor.setRejectedExecutionHandler(new ThreadPoolExecutor.CallerRunsPolicy());
executor.setWaitForTasksToCompleteOnShutdown(true); /* 等待所有任务结束后再关闭线程池 */
executor.initialize();
要设置手动释放资源,就不要使用Spring注册成Bean配置了,那这个线程池就是临时在业务方法需要调用一下
【Java】线程池配置的更多相关文章
- 【Java 并发】Executor框架机制与线程池配置使用
[Java 并发]Executor框架机制与线程池配置使用 一,Executor框架Executor框架便是Java 5中引入的,其内部使用了线程池机制,在java.util.cocurrent 包下 ...
- Java 线程池框架核心代码分析--转
原文地址:http://www.codeceo.com/article/java-thread-pool-kernal.html 前言 多线程编程中,为每个任务分配一个线程是不现实的,线程创建的开销和 ...
- Java线程池使用说明
Java线程池使用说明 转自:http://blog.csdn.net/sd0902/article/details/8395677 一简介 线程的使用在java中占有极其重要的地位,在jdk1.4极 ...
- (转载)JAVA线程池管理
平时的开发中线程是个少不了的东西,比如tomcat里的servlet就是线程,没有线程我们如何提供多用户访问呢?不过很多刚开始接触线程的开发攻城师却在这个上面吃了不少苦头.怎么做一套简便的线程开发模式 ...
- 四种Java线程池用法解析
本文为大家分析四种Java线程池用法,供大家参考,具体内容如下 http://www.jb51.net/article/81843.htm 1.new Thread的弊端 执行一个异步任务你还只是如下 ...
- Java线程池的几种实现 及 常见问题讲解
工作中,经常会涉及到线程.比如有些任务,经常会交与线程去异步执行.抑或服务端程序为每个请求单独建立一个线程处理任务.线程之外的,比如我们用的数据库连接.这些创建销毁或者打开关闭的操作,非常影响系统性能 ...
- Java线程池应用
Executors工具类用于创建Java线程池和定时器. newFixedThreadPool:创建一个可重用固定线程数的线程池,以共享的无界队列方式来运行这些线程.在任意点,在大多数 nThread ...
- [转 ]-- Java线程池使用说明
Java线程池使用说明 原文地址:http://blog.csdn.net/sd0902/article/details/8395677 一简介 线程的使用在java中占有极其重要的地位,在jdk1. ...
- Java 线程池框架核心代码分析
前言 多线程编程中,为每个任务分配一个线程是不现实的,线程创建的开销和资源消耗都是很高的.线程池应运而生,成为我们管理线程的利器.Java 通过Executor接口,提供了一种标准的方法将任务的提交过 ...
- java线程池的使用与详解
java线程池的使用与详解 [转载]本文转载自两篇博文: 1.Java并发编程:线程池的使用:http://www.cnblogs.com/dolphin0520/p/3932921.html ...
随机推荐
- C# 利用Autofac批量接口注入依赖【学习记录】
背景: 本人在一位大佬的Colder框架中看到了这个接口注入,然后呢就想学习一下ioc思想与di设计模式.此写法给我的感觉就是 非常的 优雅 ,优雅永不过时.关于接口注入的概念和ioc和di具体是什么 ...
- Adobe软件资源 PS PR AE等等
整理了一波Adobe软件,19年20年21年Mac版本的都有,关注Rand_cs即可领取
- 剑指Offer-64.滑动窗口的最大值(C++/Java)
题目: 给定一个数组和滑动窗口的大小,找出所有滑动窗口里数值的最大值.例如,如果输入数组{2,3,4,2,6,2,5,1}及滑动窗口的大小3,那么一共存在6个滑动窗口,他们的最大值分别为{4,4,6, ...
- 关于编译告警 C4819 的完整解决方案 - The file contains a character that cannot be represented in the current code page (number). Save the file in Unicode format to prevent data loss.
引言 今天迁移开发环境的时候遇到一个问题,同样的操作系统和 Visual Studio 版本,原始开发环境一切正常,但是迁移后 VS 出现了 C4819 告警,上网查了中文的一些博客,大部分涵盖几种解 ...
- MySQL常见的后端面试题,你会几道?
为什么分库分表 单表数据量过大,会出现慢查询,所以需要水平分表 可以把低频.高频的字段分开为多个表,低频的表作为附加表,且逻辑更加清晰,性能更优 随着系统的业务模块的增多,放到单库会增加其复杂度,逻辑 ...
- IP数据报分片问题
为什么要分片? 很多时候,由于单个数据太大,超过了MTU的限定值,就要对数据包进行分组,即切割并分别发送. 我们要解决以下几个问题: 1.顺序问题.接收方可以按照原来的顺序重组这些分片,并能知道这些分 ...
- Linux设备模型:5、device和device driver
作者:wowo 发布于:2014-4-2 19:28 分类:统一设备模型 http://www.wowotech.net/device_model/device_and_driver.html 前言 ...
- Windows/Linux 通过 ssh 打开 远程服务器 GUI程序
背景 在 Windows + ssh(Cygwin) + Linux(运行在虚拟机中的Ubuntu) 是一个很舒服的方案,但是偶尔需要用到 图形界面. 如果需要通过ssh打开远程服务器端的程序,需要X ...
- 题解:洛谷 P1165 日志分析
标签:栈,模拟 题意 对于一个栈,给定三种操作: 0 x,将 \(x\) 入栈: 1,出栈,栈空时忽略: 2,查询当前栈内最大值. 思路 前两个都是栈的基本操作,关键在于查最大值. 每次询问暴力找肯定 ...
- ROS让机器人开发更便捷,基于RK3568J+Debian系统发布!
ROS系统是什么 ROS(Robot Operating System)是一个适用于机器人的开源的元操作系统.它提供了操作系统应有的服务,包括硬件抽象,底层设备控制,常用函数的实现,进程间消息传递,以 ...