0

0

Java并发编程中性能问题如何定位_排查思路总结

P粉602998670

P粉602998670

发布时间:2026-01-21 17:26:02

|

656人浏览过

|

来源于php中文网

原创

快速发现Java应用响应变慢需先用jstack -l <pid>查WAITING/BLOCKED线程及重复锁对象,结合async-profiler录锁事件;GC干扰看GCDetails日志与jstat -gc;ConcurrentHashMap退化源于容量小、hashCode不均或computeIfAbsent耗时;线程池堆积要警惕CallerRunsPolicy和无界队列。

java并发编程中性能问题如何定位_排查思路总结

线程阻塞和锁竞争怎么快速发现

Java应用响应变慢、吞吐骤降,十有八九是线程卡在锁或IO上。别急着改代码,先看线程快照:jstack -l <pid> 输出里重点找 WAITINGBLOCKED 状态的线程堆,尤其是重复出现的锁对象(如 java.util.concurrent.locks.ReentrantLock$NonfairSyncsynchronized 持有的 java.lang.Object 实例)。

常见误判点:

  • parking to wait for <0x...> 当成死锁——其实只是正常 AQS 等待,得结合持有锁的线程是否在运行来判断
  • 忽略 java.lang.Thread.State: TIMED_WAITING (on object monitor),它可能正卡在 wait(timeout)Object.wait(),背后往往是生产者-消费者模型的唤醒遗漏
  • jstack 抓瞬时快照容易漏掉短时阻塞,建议配合 async-profiler 录制 30 秒锁事件:
    ./profiler.sh -e lock -d 30 -f lock.html <pid>

GC 导致并发性能抖动怎么确认

并发线程频繁进入 SAFEPOINT、RT 波动大、CPU 利用率低但延迟高,大概率是 GC 干扰。开 JVM 参数 -XX:+PrintGCDetails -XX:+PrintGCTimeStamps,观察日志中是否密集出现 Full GC 或单次 ParNew 耗时超 100ms。

关键线索:

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

Glimmer Ai
Glimmer Ai

基于GPT-3和DALL·E2的PPT制作工具

下载
  • G1 Evacuation Pause[Eden: ...->..., Survivor: ...->...] 后面如果跟着大量 to-space exhausted,说明 G1 回收不及,对象晋升太快,要检查是否有突发大对象或长生命周期缓存泄漏
  • jstat -gc <pid> 1000S0C/S1C(Survivor 容量)是否长期接近 0,这会导致对象直入老年代,加剧 CMS 或 G1 老年代压力
  • 开启 -XX:+UnlockDiagnosticVMOptions -XX:+LogVMOutput -XX:LogFile=jvm.log 可捕获 safepoint 停顿详情,定位是不是 GC 触发了全局停顿

ConcurrentHashMap put/get 性能异常慢的排查路径

不是所有“并发安全”都等于“高性能”。ConcurrentHashMap 在以下场景会退化:

  • 初始化容量过小(默认 16),且并发写入线程多 → 大量哈希冲突导致链表/红黑树深度增加 → 查找从 O(1) 退化为 O(log n);应预估 size,显式构造:new ConcurrentHashMap<>(expectedSize / 0.75f + 1)
  • key 的 hashCode() 实现不均(如永远返回固定值),所有 entry 都挤进同一个 bin → 锁粒度失效,实际串行化;用 Unsafe.compareAndSwapInt 自定义哈希时尤其要注意
  • JDK 8+ 中 computeIfAbsent 若传入的 mappingFunction 执行耗时,会阻塞同一 bin 下其他操作;避免在 lambda 里做 DB 查询或远程调用
  • 使用 size() 方法而非 isEmpty() —— 前者需遍历所有 segment 计数,后者只查一个 volatile 字段,差异可达毫秒级

线程池任务堆积却无拒绝日志?检查 CallerRunsPolicy 和队列类型

现象:监控显示 queue.size 持续上涨,但没看到 RejectedExecutionException,应用越来越慢。原因通常是用了 CallerRunsPolicy 或无界队列(如 LinkedBlockingQueue 默认 capacity=Integer.MAX_VALUE)。

真实影响:

  • CallerRunsPolicy 会让提交线程自己执行任务,表面没异常,实则把业务线程拖进 CPU 密集型逻辑,造成线程饥饿;用 jstack 会发现大量业务线程堆栈停留在 ThreadPoolExecutor$CallerRunsPolicy.rejectedExecution
  • 无界队列 + 固定大小 corePoolSize,等于把背压转移到内存——OOM 前只会越来越慢;应改用有界队列(如 ArrayBlockingQueue),并配合理想的 corePoolSize(通常 = CPU 核心数 × 1.5~2)
  • 检查 allowCoreThreadTimeOut(true) 是否误开:它会让空闲 core 线程也回收,导致突发流量来临时重建线程开销大,反而降低吞吐

真正难的不是找到哪个线程在等,而是判断它该不该等、等多久才合理。比如一个 ReentrantLock.lockInterruptibly() 卡住 200ms,可能是数据库连接池耗尽,也可能是下游服务超时配置太松——得顺着堆栈里的 at com.xxx.dao.UserDao.selectById 往下查 SQL 执行计划,而不是只盯着锁本身。

相关文章

数码产品性能查询
数码产品性能查询

该软件包括了市面上所有手机CPU,手机跑分情况,电脑CPU,电脑产品信息等等,方便需要大家查阅数码产品最新情况,了解产品特性,能够进行对比选择最具性价比的商品。

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

1134

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

340

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

381

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

2174

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

380

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1703

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

585

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

440

2024.04.29

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

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

精品课程

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

共23课时 | 4.4万人学习

C# 教程
C# 教程

共94课时 | 11.2万人学习

Java 教程
Java 教程

共578课时 | 81.3万人学习

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

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