0

0

如何通过Java自带工具分析线程状态_jstack与VisualVM使用

P粉602998670

P粉602998670

发布时间:2026-02-27 14:37:06

|

478人浏览过

|

来源于php中文网

原创

jstack快速定位线程卡死需用-l参数抓锁信息,重点分析blocked、deadlock及parking/waiting锁地址关联;visualvm远程连接须配全4个jmx参数并设-djava.rmi.server.hostname;线程泄漏要查活动线程曲线和thread实例数。

如何通过java自带工具分析线程状态_jstack与visualvm使用

线程卡死时,jstack 怎么快速抓到罪魁祸首

直接用 jstack 抓堆栈是最快定位线程阻塞/死锁的方式,但很多人输完命令只看到一堆 java.lang.Thread.State: WAITING 就懵了——关键不是状态本身,而是它停在哪一行、持有什么锁、在等谁释放。

  • 先确认目标进程 PID:jps -lps aux | grep java
  • 执行 jstack -l <pid> > thread_dump.txt</pid>-l 参数必须加,否则看不到锁信息(比如 locked waiting to lock
  • 重点关注 java.lang.Thread.State: BLOCKEDdeadlock 段落;WAITING 要结合 at 行和 locked/waiting to lock 一起看
  • 别用 jstack <pid></pid> 直接输出到终端,长堆栈容易刷屏丢失关键行;重定向到文件后用 grep -A 10 -B 5 "BLOCKED\|deadlock" 快速过滤

VisualVM 连不上远程 Java 进程?-Dcom.sun.management.jmxremote 配置漏了哪几项

VisualVM 本地连本机进程没问题,一换远程就显示“无法连接”,大概率是 JVM 启动参数没配全,或者防火墙/SELinux 拦了 JMX 端口。

  • 必须同时设置这 4 个系统属性:-Dcom.sun.management.jmxremote-Dcom.sun.management.jmxremote.port=9999-Dcom.sun.management.jmxremote.authenticate=false-Dcom.sun.management.jmxremote.ssl=false
  • -Djava.rmi.server.hostname= 这一项最容易漏——如果服务器有多个网卡或用了 Docker,RMI 默认返回 localhost 或内网地址,导致 VisualVM 连过去后二次握手失败
  • 远程端口(如 9999)要开放:检查 iptablesfirewalld,云服务器还得看安全组
  • VisualVM 插件不用额外装,自带的 “MBeans” 和 “Threads” 标签页足够查线程状态;点开线程名就能看到实时堆栈和 CPU 时间

jstack 输出里 parking to wait forwaiting on condition 到底在等什么

这两类状态常被误认为“空闲”,其实背后是典型的同步等待:前者多见于 LockSupport.park()(比如 ReentrantLockThreadPoolExecutor 工作线程),后者常见于 Object.wait()Condition.await()

ColorMagic
ColorMagic

AI调色板生成工具

下载
  • parking to wait for :说明线程正通过 AQS 等待获取某个锁对象,去堆栈里找 acquireQueuedlockInterruptibly 调用位置
  • waiting on condition :通常对应 Condition.await(),要看前一行的 at java.util.concurrent.locks.AbstractQueuedSynchronizer$ConditionObject.await,再往上翻调用链,找到业务代码里 condition.await() 的位置
  • 注意:这些锁地址(如 )在同一次 jstack 输出中是唯一的,可跨线程搜索,确认哪个线程持有它、是否已超时未唤醒

用 VisualVM 查线程泄漏,为什么“线程数持续上涨”却看不到新线程名

线程数涨得慢、名字又都是 pool-1-thread-xx 这种动态生成的,靠肉眼数名字根本不可靠;真正该盯的是“活动线程数”曲线和线程生命周期分布。

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

  • 打开 VisualVM 的 “Threads” 标签页,勾选 “Live threads only”,再点右上角 “Thread dump” 按钮,不要只看当前快照——间隔 30 秒连续抓 3 次,对比 java.lang.Thread 实例数是否稳定
  • 导出堆内存快照(Heap Dump)后,在 “Classes” 视图里搜 java.lang.Thread,看实例数是否远超预期(比如线程池核心数 × 2)
  • 常见陷阱:线程池 allowCoreThreadTimeOut(true) 没设,导致核心线程永不销毁;或 ThreadLocal 持有大对象 + 线程复用,造成内存泄漏间接拖慢线程回收
  • 如果线程名都一样,重点看堆栈最顶层:是不是全卡在 getTask()(空闲等待)、还是全堵在某个数据库连接获取、或是反复抛异常后没正确 shutdown
线程分析不是比谁 dump 得多,而是比谁能从同一串 locked 地址里串起持有者和等待者。JDK 自带工具够用,但漏掉 -ljava.rmi.server.hostname 这种细节,就等于没打开门。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

427

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

599

2023.08.10

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

427

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

599

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

721

2023.08.10

Java 并发编程高级实践
Java 并发编程高级实践

本专题深入讲解 Java 在高并发开发中的核心技术,涵盖线程模型、Thread 与 Runnable、Lock 与 synchronized、原子类、并发容器、线程池(Executor 框架)、阻塞队列、并发工具类(CountDownLatch、Semaphore)、以及高并发系统设计中的关键策略。通过实战案例帮助学习者全面掌握构建高性能并发应用的工程能力。

95

2025.12.01

k8s和docker区别
k8s和docker区别

k8s和docker区别有抽象层次不同、管理范围不同、功能不同、应用程序生命周期管理不同、缩放能力不同、高可用性等等区别。本专题为大家提供k8s和docker区别相关的各种文章、以及下载和课程。

268

2023.07.24

docker进入容器的方法有哪些
docker进入容器的方法有哪些

docker进入容器的方法:1. Docker exec;2. Docker attach;3. Docker run --interactive --tty;4. Docker ps -a;5. 使用 Docker Compose。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

514

2024.04.08

Golang 并发编程模型与工程实践:从语言特性到系统性能
Golang 并发编程模型与工程实践:从语言特性到系统性能

本专题系统讲解 Golang 并发编程模型,从语言级特性出发,深入理解 goroutine、channel 与调度机制。结合工程实践,分析并发设计模式、性能瓶颈与资源控制策略,帮助将并发能力有效转化为稳定、可扩展的系统性能优势。

2

2026.02.27

热门下载

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

精品课程

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

共23课时 | 3.9万人学习

C# 教程
C# 教程

共94课时 | 10.3万人学习

Java 教程
Java 教程

共578课时 | 73.5万人学习

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

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