Java中怎么利用 jstack分析线程状态


本篇文章给大家分享的是有关Java中怎么利用 jstack分析线程状态,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。jstck 是什么? 这个是 Oracle JDK 默认包含的一个用于打印执行 Java 进程的当前线程栈信息的工具。官方是这样介绍的:jstackprints Java stack traces of Java threads for a given Java process or core file or a remote debug server. For each Java frame, the full class name, method name, ‘bci’ (byte code index) and line number, if available, are printed.注意其中几个关键点:每一个 Java Frame 的全类名,方法名,如果能拿到行号的话还会显示行号。看过前面介绍调试技巧那篇文章(80%的程序员都不了解的调试技巧)的朋友可能还记得,其中有一个功能是Drop Frame, 来实现后退执行。和这里的是一个地方,都对应线程中的一级调用。
使用 jstack 打出来的信息,和一般应用遇到异常时的 printStackTrace 基本一样,只是那只是一个线程调用链的,这里通过工具,可以把应用内所有线程都打出来。用法使用方式和一般的 Java 分析工具类似,都是通过命令名 + pid(进程id)这种格式使用。比如对于 jstack, 一般可以直接 jstack 应用pid 即可。这里 pid 可以通过Java的 jps 工具获取,也可以通过 Linux 下的ps 工具和 Windows 下的任务管理器获取。
输出我们以一个Tomcat进程为例,输出类似这样:我们看上面的几个框:最上方左侧,是当前线程的线程名称,可以根据此来在应用内大量的线程中找到我们关心的线程正在执行的操作。例如 Tomcat 一般 http-port -x 这种线程是请求的处理线程,页面响应慢的时候,可以直接找这一类线程。随着请求的增多,线程数也会很多。所以一般多线程应用开发,一个好的实战建议是为创建的线程起一个有意义的名 香港云主机字,否则打出来的 stack 里大量的 thread -1, thread -2 这种,天晓得哪一个才是你的。第二行的框内内容,表示当前线程的执行状态,是运行状态还是TIME_WAITING,还是等待锁等,可以根据线程状态来了解。第三个大框中的内容就和我们异常时输出的 stackTrace 一样,是当前代码的调用链。第四个框中的内容,是当前线程挂的锁的情况。上面的截图,是没有锁互相占用的情况下的输出。如果一个多线程中有锁等待时,会有类似这样的输出:注意,此时线程状态变成了 BLOCKED, 同时,在线程的调用链中,有一个waiting to lock 的输出, 同时,在下方持胡锁的线程中,会有一个 lock xxx,这个是当前锁对象,通过这个就可以看出当前还有哪些线程在等待同一个锁。所以回到前面的问题,如果此时因为锁占用导致的,可以从输出中看到,同时如果是数据库连接池满了,线程就会停在数据库连接的操作上,在 stackTrace 中一眼就能看的出来,甚至网络 Socket 读取之类的在等待,都会在调用链中体现出来,从而可以快速的定位问题,解决问题。
以上就是Java中怎么利用 jstack分析线程状态,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注开发云行业资讯频道。

相关推荐: Win7系统8080端口被占用怎么解决

本篇内容主要讲解“Win7系统8080端口被占用怎么解决”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Win7系统8080端口被占用怎么解决”吧!解决方法:1、按 Win + R 组合键,打开运行,并输入:cmd,…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 07/30 16:44
下一篇 07/30 16:44

相关推荐