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 保证线程安全的
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