实际开发中Java线程池怎么配

前言

在实际开发中,业务场景是多种多样的,分为IO密集型与CPU密集型俩种。针对不同的场景。如何配置一个合理的线程池是十分重要的~。
接下来我从Java线程池的生命周期以及实际开发场景讲解如何配置Java线程池

Java线程池

线程池七大参数

  • 核心线程数
  • 最大线程数
  • 线程空闲保持时间
  • 时间单位
  • 等待队列(存放待执行的队列):
  • 线程创建工厂
  • 拒绝策略

等待队列分有界与无界俩种
有界:有长度,会触发拒绝策略
无界:无限添加
一般实际开发中都是用有界的。避免历史线程造成服务的不可用

Java线程池创建线程的生命周期

Java线程池中线程是在使用时创建的,并非在线程池创建时

  1. 当并发线程数< 核心线程数时:创建核心线程
  2. 核心线程已满时:新线程进入等待队列
  3. 等待队列已满时:创建最大线程数
  4. 当等待队列已满&&达到最大线程数时:新线程进入触发拒绝策略
  5. 当最大线程数空闲超过空闲保持时间时:线程销毁(非核心线程)===>. 作用:避免线程数过多造成线程切换的消耗

Java线程池的拒绝策略

  1. 抛出异常
  2. 由调用线程执行(串型,不走多线程)
  3. 直接丢弃
  4. 丢弃最早未处理任务(LRU)

实际开发配置

对Java线程池有了了解后,就可以针对不同的场景去配置线程池了

IO密集型

解释

IO密集型是指内存传输操作较多,CPU有大量时间处于等待IO的状态下。
这个时候需要增大线程数,配置更多的线程来充分利用CPU。

实际配置
  • 核心线程数:通常是CPU核数的2~4倍。根据实际IO等待时间而定
  • 最大线程数:通常是核心线程数的2倍
  • 队列:有界队列,长度可以大一点. 可以配在100左右(根据核数定)
  • 拒绝策略:拒绝策略一般按需求定. 常用的是:抛出异常 或者 由调用线程执行
  • 最大空闲时间:一般是30~60s,根据qps是否平均而定

CPU密集型

解释

CPU密集型任务是指计算操作较多,CPU资源是瓶颈。
因此线程数不宜过多,以避免过度上下文切换。

实际配置
  • 核心线程数:CPU核数+1。略多于CPU核数即可
  • 最大线程数:核心线程数+1。略多于核心线程数即可
  • 队列:有界队列,长度不用过大. 可以配置在50左右
  • 拒绝策略:拒绝策略一般按需求定. 常用的是:抛出异常 或者 由调用线程执行
  • 最大空闲时间:一般是30~60s,根据qps是否平均而定

总结

IO密集型任务:配置更多线程(通常是CPU核心数的2到4倍),以充分利用CPU资源。
CPU密集型任务:配置接近于CPU核心数的线程数,以避免过度上下文切换。

思考

知道单机QPS怎么配置线程池?
  1. 先计算并发线程数:并发线程数= QPS * T(平响)
  2. 判断场景类型:IO密集型 or CPU密集型
    • IO密集型:
      • 核心线程数:并发线程数
      • 最大线程数:核心线程数 * 2
    • CPU密集型:
      • 核心线程数:CPU核数+1
      • 最大线程数:略多于核心线程数

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/861628.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

关于服务器的一些知识

1. 云服务器 和 轻量应用服务器 腾讯云中的"云服务器"&#xff08;Cloud Virtual Machine, CVM&#xff09;和"轻量应用服务器"&#xff08;Lite Cloud Server&#xff09;都是提供云端计算资源的服务&#xff0c;但它们在定位、特性和使用场景上存在一些差…

【昇思大模型平台体验篇】day1快速入门

早闻毕晟、昇思等平台&#xff0c;今日有机会能参加入门课程&#xff0c;非视频课程算是我第一次看&#xff0c;也算是对我自己的一个锻炼&#xff0c;之前也没有系统学习模型之类&#xff0c;每天抽出一点点时间来学习一下也是不错的 MindSpore 看来是和torch类似的结构 处理…

GPT5将引领第四次工业革命:人工智能、物联网、大数据、生物技术、量子计算等的综合体GPT大模型将改变很多现在的工作方式和生活方式,人人必读,人人必用

2024年6月22日&#xff0c;美国达特茅斯工程学院的一场采访引起了全球科技界的广泛关注。OpenAI首席技术官米拉穆拉蒂在采访中确认&#xff0c;备受期待的GPT-5将在一年半后发布。 这一消息不仅激起了科技界的热烈讨论&#xff0c;也让人们对人工智能&#xff08;AI&#xff09…

LongRAG:利用长上下文大语言模型提升检索生成效果

一、前言 前面我们已经介绍了多种检索增强生成 (RAG) 技术&#xff0c;基本上在保证数据质量的前提下&#xff0c;检索增强生成&#xff08;RAG&#xff09;技术能够有效提高检索效率和质量&#xff0c;相对于大模型微调技术&#xff0c;其最大的短板还是在于有限的上下文窗口…

幽默证明题!高考成绩公布后,妈妈连夜写了一封信:孩子,这就是我不让你玩手机的原因——早读(逆天打工人爬取热门微信文章解读)

毛毛雨&#xff0c;五分钟结束&#xff0c;怎么证明今天早上有下雨呢&#xff1f; 引言Python 代码第一篇 洞见 高考成绩公布后&#xff0c;妈妈连夜写了一封信&#xff1a;孩子&#xff0c;这就是我不让你玩手机的原因第二篇 视频新闻结尾 引言 今天睡眠质量不错 发现一个问题…

10分钟微调专属于自己的大模型_10分钟微调大模型

1.环境安装 # 设置pip全局镜像 (加速下载) pip config set global.index-url https://mirrors.aliyun.com/pypi/simple/ # 安装ms-swift pip install ms-swift[llm] -U# 环境对齐 (通常不需要运行. 如果你运行错误, 可以跑下面的代码, 仓库使用最新环境测试) pip install -r r…

面试专区|【88道Vue高频题整理(附答案背诵版)】

1、请简述Vue插件和组件的区别 &#xff1f; Vue的插件&#xff08;Plugin&#xff09;和组件&#xff08;Component&#xff09;是Vue.js中非常重要的两个概念&#xff0c;它们在功能上有着明显的差异。 Vue组件&#xff08;Component&#xff09;&#xff1a; Vue组件是Vue…

vb6多线程异步,VB.NET 全用API实现:CreateThread创建多线程,等待线程完成任务

在VB.NET中&#xff0c;你可以使用API函数来创建多线程并等待线程完成任务。以下是一个示例代码&#xff0c;展示如何使用API函数来实现这个功能&#xff1a; Imports System.Runtime.InteropServices Imports System.ThreadingPublic Class Form1Private Delegate Sub ThreadC…

大模型+多模态合规分析平台,筑牢金融服务安全屏障

随着金融市场的快速发展&#xff0c;金融产品和服务日趋多样化&#xff0c;消费者面临的风险也逐渐增加。 为保护消费者权益&#xff0c;促进金融市场长期健康稳定发展&#xff0c;国家监管机构不断加强金融监管&#xff0c;出台了一系列法律法规和政策文件。对于金融从业机构…

【DC-DC升压电推剪方案】FP6277,FP6296电源升压芯片在电推剪中扮演着一个怎样的角色?带你深入了解电推剪的功能和应用及工作原理

随着人们对个人形象要求的不断提高&#xff0c;理发器作为一个必备的家居用品&#xff0c;也在不断进行技术升级。而其中的核心装备之一&#xff0c;电推剪理发器升压芯片FP6277、FP6296&#xff0c;正在引领着现代理发技术的突破。本文将给大家带来的是电推剪在传统意义上运用…

keil仿真,查看函数执行时间和执行次数

Execution Profiler执行档案器 The Execution Profiler records timing and execution statistics about instructions for the complete program code. To view the values in the Editor or Disassembly Window, use Show Time or Show Calls from the menu Debug — Executi…

[vue]打包后发布相关问题总结

问题1&#xff1a; 1. history模式下&#xff0c;发布到nginx后&#xff0c;刷新页面或者地址栏回车404问题。 打开nginx的nginx.conf文件&#xff0c;添加注释【2】对应行的代码&#xff0c;可以解决这个问题。 events {worker_connections 1024; }http {include mime.typ…

6.18-6.26 旧c语言

第一章 概述 32关键字 9种控制语句 优点&#xff1a;能直接访问物理地址&#xff0c;位操作&#xff0c;代码质量高&#xff0c;执行效率高 可移植性好 面向过程&#xff1a;以事件为中心 面向对象&#xff1a;以实物为中心 printf&#xff1a;系统定义的标准函数 #include&l…

Java并发编程中的线程局部变量ThreadLocal variables的关键点是什么?

ThreadLocal变量的关键点 ThreadLocal变量是Java中用于实现线程局部存储的一种机制&#xff0c;它允许每个线程拥有自己的变量副本&#xff0c;从而避免了多线程环境下变量共享导致的并发问题。以下是ThreadLocal变量的几个关键点&#xff1a; 线程隔离&#xff1a;ThreadLoc…

探索 JQuery EasyUI:构建简单易用的前端页面

介绍 当我们站在网页开发的浩瀚世界中&#xff0c;眼花缭乱的选择让我们难以抉择。而就在这纷繁复杂的技术海洋中&#xff0c;JQuery EasyUI 如一位指路明灯&#xff0c;为我们提供了一条清晰的航线。 1.1 什么是 JQuery EasyUI&#xff1f; JQuery EasyUI&#xff0c;简单来…

DM达梦数据库转换、条件函数整理

&#x1f49d;&#x1f49d;&#x1f49d;首先&#xff0c;欢迎各位来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里不仅可以有所收获&#xff0c;同时也能感受到一份轻松欢乐的氛围&#xff0c;祝你生活愉快&#xff01; &#x1f49d;&#x1f49…

分享AI学习笔记之Python

当你说"抓取网站数据"时&#xff0c;通常指的是网络爬虫&#xff08;web scraping&#xff09;或网络抓取&#xff08;web crawling&#xff09;。Python提供了很多库可以帮助你实现这个功能&#xff0c;其中最常见的有requests&#xff08;用于发送HTTP请求&#xf…

【乐吾乐2D可视化组态编辑器】画布

5.1 设置画布属性 默认颜色&#xff1a;预先设置默认颜色&#xff0c;拖拽到画布的节点&#xff08;基础图形、文字、icon&#xff09;自动统一默认颜色。 画笔填充颜色&#xff1a;预先设置画笔填充颜色&#xff0c;拖拽到画布的节点&#xff08;基础图形&#xff09;自动统…

QT自定义信号和槽函数

在QT中最重要也是必须要掌握的机制&#xff0c;就是信号与槽机制&#xff0c;在MFC上也就是类型的机制就是消息与响应函数机制 在QT中我们不仅要学会如何使用信号与槽机制&#xff0c;还要会自定义信号与槽函数&#xff0c;要自定义的原因是系统提供的信号&#xff0c;在一些情…

免费录制视频软件推荐,这3款软件超实用!

随着网络技术的发展&#xff0c;录制视频已经成为人们日常生活中的一个重要需求。无论是教学、会议、游戏还是娱乐&#xff0c;视频录制都为我们提供了极大的便利。然而&#xff0c;市场上的视频录制软件琳琅满目&#xff0c;如何选择一款适合自己的免费录制视频软件成为了一个…