问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

如何分析线程堆栈

发布网友 发布时间:2022-05-13 03:48

我来回答

1个回答

热心网友 时间:2023-11-16 06:32

  JVM线程堆栈是一个给定时间的快照,它能向你提供所有被创建出来的Java线程的完整清单.

  每一个被发现的Java线程都会给你如下信息:

  – 线程的名称;经常被中间件厂商用来识别线程的标识,一般还会带上被分配的线程池名称以及状态 (运行,阻塞等等.)

  – 线程类型 & 优先级,例如 : daemon prio=3 ** 中间件程序一般以后台守护的形式创建他们的线程,这意味着这些线程是在后台运行的;它们会向它们的用户提供服务,例如:向你的Java EE应用程序 **

  – Java线程ID,例如 : tid=0x000000011e52a800 ** 这是通过 java.lang.Thread.getId() 获得的Java线程ID,它常常用自增长的长整形 1..n** 实现

  – 原生线程ID,例如 : nid=0x251c** ,之所以关键是因为原生线程ID可以让你获得诸如从操作系统的角度来看那个线程在你的JVM中使用了大部分的CPU时间等这样的相关信息. **

  – Java线程状态和详细信息,例如: waiting for monitor entry [0xfffffffea5afb000] java.lang.Thread.State: BLOCKED (on object monitor)
  ** 可以快速的了解到线程状态极其当前阻塞的可能原因 **

  – Java线程栈跟踪;这是目前为止你能从线程堆栈中找到的最重要的数据. 这也是你花费最多分析时间的地方,因为Java栈跟踪向提供了你将会在稍后的练习环节了解到的导致诸多类型的问题的根本原因,所需要的90%的信息。

  – Java 堆内存分解; 从HotSpot VM 1.6版本开始,在线程堆栈的末尾处可以看到HotSpot的内存使用情况,比如说Java的堆内存(YoungGen, OldGen) & PermGen 空间。这个信息对分析由于频繁GC而引起的问题时,是很有用的。你可以使用已知的线程数据或模式做一个快速的定位。

  Heap
  PSYoungGen total 466944K, used 178734K [0xffffffff45c00000, 0xffffffff70800000, 0xffffffff70800000)
  eden space 233472K, 76% used [0xffffffff45c00000,0xffffffff50ab7c50,0xffffffff54000000)
  from space 233472K, 0% used [0xffffffff62400000,0xffffffff62400000,0xffffffff70800000)
  to space 233472K, 0% used [0xffffffff54000000,0xffffffff54000000,0xffffffff62400000)
  PSOldGen total 1400832K, used 1400831K [0xfffffffef0400000, 0xffffffff45c00000, 0xffffffff45c00000)
  object space 1400832K, 99% used [0xfffffffef0400000,0xffffffff45bfffb8,0xffffffff45c00000)
  PSPermGen total 262144K, used 248475K [0xfffffffed0400000, 0xfffffffee0400000, 0xfffffffef0400000)
  object space 262144K, 94% used [0xfffffffed0400000,0xfffffffedf6a6f08,0xfffffffee0400000)
  线程堆栈信息大拆解

  为了让大家更好的理解,给大家提供了下面的这张图,在这张图中将HotSpot VM上的线程堆栈信息和线程池做了详细的拆解,如下图所示:

  上图中可以看出线程堆栈是由多个不同部分组成的。这些信息对问题分析都很重要,但对不同的问题模式的分析会使用不同的部分(问题模式会在后面的文章中做模拟和演示。)

  现在通过这个分析样例,给大家详细解释一下HoteSpot上线程堆栈信息中的各个组成部分:

  # Full thread mp标示符

  “Full thread mp”是一个全局唯一的关键字,你可以在中间件和单机版本Java的线程堆栈信息的输出日志中找到它(比如说在UNIX下使用:kill -3 <PID> )。这是线程堆栈快照的开始部分。

  Full thread mp Java HotSpot(TM) 64-Bit Server VM (20.0-b11 mixed mode):
  # Java EE 中间件,第三方以及自定义应用软件中的线程

  这个部分是整个线程堆栈的核心部分,也是通常需要花费最多分析时间的部分。堆栈中线程的个数取决你使用的中间件,第三方库(可能会有独立线程)以及你的应用程序(如果创建自定义线程,这通常不是一个很好的实践)。

  在我们的示例线程堆栈中,WebLogic是我们所使用的中间件。从Weblogic 9.2开始, 会使用一个用“’weblogic.kernel.Default (self-tuning)”唯一标识的能自行管理的线程池

  "[STANDBY] ExecuteThread: '414' for queue: 'weblogic.kernel.Default (self-tuning)'" daemon prio=3 tid=0x000000010916a800 nid=0x2613 in Object.wait() [0xfffffffe9edff000]
  java.lang.Thread.State: WAITING (on object monitor)
  at java.lang.Object.wait(Native Method)
  - waiting on <0xffffffff27d44de0> (a weblogic.work.ExecuteThread)
  at java.lang.Object.wait(Object.java:485)
  at weblogic.work.ExecuteThread.waitForRequest(ExecuteThread.java:160)
  - locked <0xffffffff27d44de0> (a weblogic.work.ExecuteThread)
  at weblogic.work.ExecuteThread.run(ExecuteThread.java:181)
  # HotSpot VM 线程

  这是一个有Hotspot VM管理的内部线程,用于执行内部的原生操作。一般你不用对此操太多心,除非你(通过相关的线程堆栈以及 prstat或者原生线程Id)发现很高的CPU占用率.

  "VM Periodic Task Thread" prio=3 tid=0x0000000101238800 nid=0x19 waiting on condition
  # HotSpot GC 线程

  当使用 HotSpot 进行并行 GC (如今在使用多个物理核心的环境下很常见), 默认创建的HotSpot VM 或者每个JVM管理一个有特定标识的GC线程时. 这些GC线程可以让VM以并行的方式执行其周期性的GC清理, 这会导致GC时间的总体减少;与此同时的代价是CPU的使用时间会增加.

  "GC task thread#0 (ParallelGC)" prio=3 tid=0x0000000100120000 nid=0x3 runnable
  "GC task thread#1 (ParallelGC)" prio=3 tid=0x0000000100131000 nid=0x4 runnable
  ………………………………………………………………………………………………………………………………………………………………
  这事非常关键的数据,因为当你遇到跟GC有关的问题,诸如过度GC、内存泄露等问题是,你将可以利用这些线程的原生Id值关联的操作系统或者Java线程,进而发现任何对CPI时间的高占用. 未来的文章你将会了解到如何识别并诊断这样的问题.

  # JNI 全局引用计数

  JNI (Java 本地接口)的全局引用就是从本地代码到由Java垃圾收集器管理的Java对象的基本的对象引用. 它的角色就是阻止对仍然在被本地代码使用,但是技术上已经不是Java代码中的“活动的”引用了的对象的垃圾收集.

  同时为了侦测JNI相关的泄露而留意JNI引用也很重要. 如果你的程序直接使用了JNI,或者像*这样的第三方工具,就容易造成本地的内存泄露.

  JNI global references: 1925
  # Java 堆栈使用视图

  这些数据被添加回了 JDK 1 .6 ,向你提供有关Hotspot堆栈的一个简短而快速的视图. 我发现它在当我处理带有过高CPU占用的GC相关的问题时非常有用,你可以在一个单独的快照中同时看到线程堆栈以及Java堆的信息,让你当时就可以在一个特定的Java堆内存空间中解析(或者排除)出任何的关键点. 你如在我们的示例线程堆栈中所见,Java 的堆 OldGen 超出了最大值!

  Heap
  PSYoungGen total 466944K, used 178734K [0xffffffff45c00000, 0xffffffff70800000, 0xffffffff70800000)
  eden space 233472K, 76% used [0xffffffff45c00000,0xffffffff50ab7c50,0xffffffff54000000)
  from space 233472K, 0% used [0xffffffff62400000,0xffffffff62400000,0xffffffff70800000)
  to space 233472K, 0% used [0xffffffff54000000,0xffffffff54000000,0xffffffff62400000)
  PSOldGen total 1400832K, used 1400831K [0xfffffffef0400000, 0xffffffff45c00000, 0xffffffff45c00000)
  object space 1400832K, 99% used [0xfffffffef0400000,0xffffffff45bfffb8,0xffffffff45c00000)
  PSPermGen total 262144K, used 248475K [0xfffffffed0400000, 0xfffffffee0400000, 0xfffffffef0400000)
  object space 262144K, 94% used [0xfffffffed0400000,0xfffffffedf6a6f08,0xfffffffee0400000)
  我希望这篇文章能对你理解Hotspot VM线程堆栈的基本信息有所帮助。
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
mofile里面的视频能下载吗?怎么下? 谁有现在能用的MOFILE网站视频下载方法? MOFILE等视频网站的视频文件怎么下载啊,谢谢大家 mofile如何下载共享文件 怎么使用MOFILE下载视频? ...猪脚在主神空间第一个任务是生化,然后去梦魇空间做卧底,自己有一个... 赣商纵横长三角 想买个金的戒指送给妈妈,价格在2000以内,过年前买好还是年后买好? ...买什么牌子的好,价钱在1500左右,款式简单就好 怀孕晚期能不能吃鹅肉 进程线程与栈,堆的关系 御龙在天登录游戏后,每隔5分钟掉线,遇到未知错误,重新安装后,还是老问题,腾讯客服只会敷衍,全吃屎的 怎么知道当前线程用了多少堆栈 求javascript注册页面的生日正则表达式 青岛民办幼儿园法人变更 javascript 中如何用正则表达式 获取当前页面的所有css样式标签,所有javascript标签。 在oracle数据库中为什么char类型的9会比10大?是因为位置的关联,还是取MAX的时候只取的一位? 为什么oracle数据库中char数据类型最大取值为2000 怎样消除空调滴水声 小手指往后用力折了怎么办,很痛好像骨折 空调制热滴水怎么解决 我的手指折到了? 空调结露滴水怎样消除 手指折(zhe )了一下,没骨折但是很疼,怎么治疗? 电脑主机后面红绿蓝三个插孔,红和绿插耳机,蓝的插音响为什么没声音? 电脑机箱后面的插孔听不到声音,前面的插孔听得到声音的话,怎样能让机箱后面插孔听得到声音呢? 怎样预防QQ号被盗? 怎样防止自己的QQ号被盗 没有银行卡怎么绑定微信银行卡 微信无法添加银行卡 但可以转账 为什么线程调度要用到堆栈 JVM:如何分析线程堆栈 线程池会吃掉堆栈,能不能想办法,在异氖焙打印出 提交任务的线程的堆 c# 当前线程处于堆栈溢出状态,因此无法计算表达式的值。 Java中某一特定线程的具体任务在哪个方法中执行? 当出现死锁的时候,线程的堆栈如何?各线程处于何种状态? 检验士非统招可以报名吗 检验士什么时候报名 求一篇《这就是我》的作文 我是男生哦 这就是我 作文500字男生 这就是我 初中作文400字 男 这就是我500字的初中作文要男孩的!!! 这就是我作文800以上 PHP用正则表达式做注册页面 word的表格怎样制作斜线表头 华为yes是什么意思呢? 如何查看电脑office激活情况 能恢复一年前误删的照片吗,保存过在相册 小米手机 找回来的话400块钱 有人知道小米手机怎么恢复删除的照片吗,我攒了一年多的照片全部误删了,跪求,我的手机系统是MIUI7 小米手机以前的照片删除了怎么还能看到?