1 如何解读堆栈

线程的名字,ID,线程的数量等。

线程的运行状态,锁的状态(锁被哪个线程持有,哪个线程再等待锁等)。

调用堆栈(即函数的调用层次关系)。调用堆栈包含完整的类名,所执行的方法,源代码 的行数。

2 可以解决哪些问题

系统无缘无故CPU过高。
系统挂起,无响应。
系统运行越来越慢。
性能瓶颈(如无法充分利用CPU等) • 线程死锁、死循环,饿死等。

由于线程数量太多导致系统失败(如无法创建线程等)。

3 如何查看线程信息

ps -ef|grep java

pstack 进程号

nid 和tid区别

4 runnable状态 怎么理解

5 怎样判定 线程在消耗CPU?

处于TIMED_WAITING、WAINTING状态的线程一定不消耗CPU. 处于RUNNABLE的线

程,要结合当前线程代码的性质判断,是否消耗CPU.

如果是纯Java运算代码,则消耗CPU.

如果是网络IO,很少消耗CPU.

如果是本地代码,结合本地代码的性质判断(可以通过pstack/gstack获取本地线程堆栈), 如果是纯运算代码,则消耗CPU, 如果被挂起,则不消耗CPU,如果是IO,则不怎么消 耗CPU。

6 clinit 和 init 初始化类

Java 编译器把所有的类变量初始化语句和类型的静态 初始化器通通收集到 方法内,该方法只能被Jvm 调用,专门承担初始化工作

初始化一个类之前必须保证其直接超类已被初始化,并且该初始化过程是由Jvm 保证线程安全的

7 如何利用堆栈信息查问题

堆栈的局部信息、一次堆栈的统计信息(全 局信息)、多个堆栈的对比信息。

8 死锁的两个或多个线程是不消耗CPU的,无限循环(即死循环),并且在循 环中代码都是CPU密集型,才有可能导致CPU的100%使用率,像socket或者数据库等IO操作是 不怎么消耗CPU的。

9 死循环情况:

HashMap等线程不安全的容器,用在多线程读/写的场合,导致HashMap的方法调用形成死循环

多线程场合,对共享变量没有进行保护,导致数据混乱,从而使循环退出的条件永远不满 足,导致死循环的发生,如

_ for,while循环中的退出条件永远不满足导致的死循环。

– 链表等数据结构首尾相接,导致遍历永远无法停止。

10 也可能由于算法过于复杂,也会导致CPU过高

11 top 查询占用比较大的进程,

https://www.cnblogs.com/myna/p/7573843.html

jmap -heap pid 查看堆占用详情

jmap -histo:hive pid 查看存活的类信息

jmap -dump:hive,format=b,file=dump.hprof pid 导出dump文件

通过jhat 查看dump文件

jhat -J-Xmx1024m D:/javaDump.hprof http://localhost:7000/ 查看信息

http://localhost:7000/oqlhelp/ 查询信息

http://blog.csdn.net/renfufei/article/details/41444559

http://blog.csdn.net/xybelieve1990/article/details/53516437

监测命令(jvisualvm jps jstat jmap jhat jstack jinfo)及dump堆内存快照分析

jps查看出当前有哪些Java进程 jps -ml

jstack jstack主要用来查看某个Java进程内的线程堆栈信息

jstat -gcutil pid 查询gc