0

0

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

P粉602998670

P粉602998670

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

|

656人浏览过

|

来源于php中文网

原创

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

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

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

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

常见误判点:

  • parking to wait for 当成死锁——其实只是正常 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 

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

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

关键线索:

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

造梦阁AI
造梦阁AI

AI小说推文一键成片,你的故事值得被看见

下载
  • G1 Evacuation Pause[Eden: ...->..., Survivor: ...->...] 后面如果跟着大量 to-space exhausted,说明 G1 回收不及,对象晋升太快,要检查是否有突发大对象或长生命周期缓存泄漏
  • jstat -gc 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

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

841

2023.06.15

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

742

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

739

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

397

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

399

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

446

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

430

2023.08.02

java在线网站
java在线网站

Java在线网站是指提供Java编程学习、实践和交流平台的网络服务。近年来,随着Java语言在软件开发领域的广泛应用,越来越多的人对Java编程感兴趣,并希望能够通过在线网站来学习和提高自己的Java编程技能。php中文网给大家带来了相关的视频、教程以及文章,欢迎大家前来学习阅读和下载。

16926

2023.08.03

Java编译相关教程合集
Java编译相关教程合集

本专题整合了Java编译相关教程,阅读专题下面的文章了解更多详细内容。

9

2026.01.21

热门下载

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

精品课程

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

共23课时 | 2.7万人学习

C# 教程
C# 教程

共94课时 | 7.2万人学习

Java 教程
Java 教程

共578课时 | 48.8万人学习

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

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