0

0

在Java里为什么要使用线程池_Java性能优化说明

P粉602998670

P粉602998670

发布时间:2026-02-08 09:45:12

|

646人浏览过

|

来源于php中文网

原创

线程频繁创建销毁拖慢Java应用,因每次new Thread()都触发操作系统资源分配,导致OOM或CPU陷入上下文切换;应使用显式配置的ThreadPoolExecutor替代Executors工具类,并合理设置核心线程数、队列容量与拒绝策略。

在java里为什么要使用线程池_java性能优化说明

线程频繁创建销毁为什么拖慢Java应用

每次 new Thread().start() 都会触发操作系统级资源分配:内存(默认1MB)、内核线程、调度上下文。高并发下,线程数暴涨会导致OOM或CPU陷入无休止的上下文切换——你看到的“卡顿”,大概率不是业务慢,而是JVM在疲于调度。

实操建议:

  • 单次请求若开启5个新线程,QPS到200时,每秒就新建1000个线程;而一个空闲线程仍占约1MB堆外内存
  • jstack 查看线程 dump,如果 java.lang.Thread.State: RUNNABLE 下大量线程名含 pool-worker,说明线程池已介入;若全是 Thread-XX,基本是裸写 new Thread
  • Spring Boot 默认 Web 容器(Tomcat)本身用线程池处理 HTTP 请求,再在 Controller 里 new Thread 属于“套娃式资源滥用”

Executors.newFixedThreadPool() 为什么在生产环境不推荐

它底层用的是 LinkedBlockingQueue,且队列容量为 Integer.MAX_VALUE。任务持续涌入时,队列无限堆积,最终耗尽堆内存——错误不会立刻暴露,而是缓慢 OOM,排查困难。

更危险的是:它返回的 ThreadPoolExecutor 被包装成 ExecutorService,你无法调用 setCorePoolSize()allowCoreThreadTimeOut() 等关键方法。

立即学习Java免费学习笔记(深入)”;

实操建议:

  • 改用显式构造 ThreadPoolExecutor,例如:
    new ThreadPoolExecutor(4, 8, 60L, TimeUnit.SECONDS, new ArrayBlockingQueue(100))
  • 拒绝策略别用默认 AbortPolicy(抛 RejectedExecutionException),至少选 CallerRunsPolicy,让调用线程自己执行任务,起到自然降速作用
  • 给线程池命名,比如 new ThreadFactoryBuilder().setNameFormat("order-process-pool-%d").build(),方便 jstack 或监控系统识别

线程池参数怎么定:核心线程数不是随便拍的

没有银弹公式,但可分场景估算:

纯 CPU 密集型(如加解密、图像处理):核心线程数 ≈ CPU 核数(Runtime.getRuntime().availableProcessors()),再多只会增加上下文切换开销。

IO 密集型(如数据库查询、HTTP 调用):需结合平均等待时间估算。例如一次 DB 查询平均阻塞 100ms,而 CPU 计算仅 10ms,那么单核可“掩盖”约 11 倍 IO 时间,理论并发度 ≈ 核数 × (1 + 平均等待时间 / 平均 CPU 时间) ≈ 12(以 8 核为例)。

实操建议:

  • 别迷信“核数 × 2”,先压测:用 JMeter 模拟真实流量,观察 ThreadPoolExecutor.getActiveCount() 和 GC 时间变化
  • 监控 getQueue().size(),持续 > 队列容量 70%,说明处理能力不足或任务响应过慢
  • 避免把定时任务(ScheduledThreadPoolExecutor)和业务线程池混用,否则一个慢任务会拖垮整个调度节奏

线程池关闭不等于任务结束:shutdown() 和 shutdownNow() 的区别

shutdown() 是温和方式:不再接收新任务,但会等正在执行的和队列中已提交的任务完成;shutdownNow() 则直接中断所有运行中线程,并返回未执行的任务列表——但中断(interrupt())是否生效,取决于任务内部是否响应中断信号。

常见错误:Web 应用在 @PreDestroy 里只调 shutdownNow(),却没检查返回的任务列表,导致部分异步日志、消息发送丢失。

实操建议:

  • Spring 管理的 Bean 中,用 @PreDestroy + shutdown(),再配合 awaitTermination(30, TimeUnit.SECONDS) 等待完成,超时再 shutdownNow()
  • 对不可中断的阻塞操作(如老版本 JDBC Connection.createStatement()),考虑设置 socket timeout 或改用响应式驱动(R2DBC)
  • 线程池生命周期应与应用容器一致;不要在方法内临时创建又关闭,那是对线程池本意的背叛
线程池不是“用了就快”的开关,参数配错、关闭遗漏、任务不守规矩,都会让性能优化变成负优化。最常被忽略的一点:线程池里的任务,必须是短小、无状态、可重复执行的;一旦混入长事务或全局锁,整个池子就成了串行瓶颈。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
如何配置Tomcat环境变量
如何配置Tomcat环境变量

配置Tomcat环境变量需要在系统中添加CATALINA_HOME变量,并将Tomcat的安装路径添加到PATH变量中。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

114

2023.10.26

idea如何集成Tomcat
idea如何集成Tomcat

idea集成Tomcat的步骤:1、添加Tomcat服务器配置;2、配置项目部署;3、运行Tomcat服务器;4、访问项目;5、注意事项;6、关闭Tomcat服务器。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

169

2024.02.23

怎么查看Tomcat源代码
怎么查看Tomcat源代码

查看Tomcat源代码的步骤:1、下载Tomcat源代码;2、在IDEA中导入Tomcat源代码;3、查看源代码;4、理解Tomcat的工作原理;5、参与社区和贡献;6、注意事项;7、持续学习和更新;8、使用工具和插件。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

98

2024.02.23

常见的tomcat漏洞有哪些
常见的tomcat漏洞有哪些

常见的tomcat漏洞有:1、跨站脚本攻击;2、跨站请求伪造;3、目录遍历漏洞;4、缓冲区溢出漏洞;5、配置漏洞;6、第三方组件漏洞。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

166

2024.02.23

tomcat日志乱码怎么解决
tomcat日志乱码怎么解决

tomcat日志乱码的解决办法:1、修改tomcat的日志编码设置;2、检查ide的编码设置;3、检查操作系统的编码设置;4、使用过滤器处理日志;5、检查外部系统的编码设置;6、检查文件编码方式等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

154

2024.02.23

weblogic和tomcat有哪些区别
weblogic和tomcat有哪些区别

weblogic和tomcat的区别:1、功能;2、性能;3、规模;4、价格;5、安全性;6、配置和管理;7、社区支持;8、集成能力;9、升级和更新;10、可靠性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

199

2024.02.23

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

236

2024.02.23

tomcat启动闪退怎么解决
tomcat启动闪退怎么解决

tomcat启动闪退的解决办法:1、检查java环境;2、检查环境变量配置;3、检查端口被占用;4、检查配置文件编码;5、检查启动时需要的配置文件;6、检查相关文件是否丢失;7、检查防火墙和杀毒软件设置。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

165

2024.02.23

Golang处理数据库错误教程合集
Golang处理数据库错误教程合集

本专题整合了Golang数据库错误处理方法、技巧、管理策略相关内容,阅读专题下面的文章了解更多详细内容。

67

2026.02.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 3.4万人学习

C# 教程
C# 教程

共94课时 | 8.9万人学习

Java 教程
Java 教程

共578课时 | 60.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号