前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >jstack:java 堆栈工具

jstack:java 堆栈工具

作者头像
爱明依
发布2019-03-12 15:53:23
2.1K0
发布2019-03-12 15:53:23
举报
文章被收录于专栏:爱明依爱明依

生成线程快照的主要目的就是定位线程出现长时间停顿的原因,如线程死锁,死循环请求外部资源导致的长时间等待等都是导致线程长时间停顿的常见原因。线程出现停顿的时候通过jstack来查看各个线程的调用堆栈,就可以知道没有响应的线程到底在后台做些什么事情,或者等待着什么资源。

jstack 命令格式

jstack [option] vmid

以下是jstack 工具的主要选项

-F

当正常输出的请求不被响应时,强制输出线程堆栈

-l

除堆栈外,显示关于锁的附加信息

-m

如果调用到本地方法的话,可以显示c/c++的堆栈

在jdk1.5中,java.lang.Thread 类新增了一个getAllStackTraces() 方法用于获取虚拟机中所有线程的StackTraceElement 对象。使用这个方法几行代码就完成jstack

的大部分功能。在实际项目中,不妨调用这个方法作为管理员页面,可以随时使用浏览器来查看线程堆栈。

for(Map.Entry<Thread,StackTraceElement[]> stackTrace:Thread.getAllStackTraces().entrySet()){ Thread thread=(Thread)stackTrace.getKey(); StackTraceElement[] stack=(StackTraceElement[])stackTrace.getValues(); if(thread.equals(Thread.currentThread())){ continue; } System.out.println("\n线程"+thread.getName()+"\n"); for(StackTraceElement element:stack){ System.out.println("\n"+element+"\n"); } }

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018年01月20日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档