JVM-虚拟机栈

一、概念

Java虚拟机栈是Java虚拟机内存结构中的一部分,是每个线程运行的内存空间。每个虚拟机栈由多个栈帧组成,每次调用一个方法会创建一个新的栈帧。

二、栈内存溢出

由于栈帧过多,导致栈帧所用的内存之和超出了给栈分配的内存,造成了StackOverflow错误。用-Xss参数可以设置栈的大小,例如-Xss256k表示设置栈的大小是256k字节

三、线程运行诊断
案例1:CPU占用过高
  1. 用top命令找到哪个进程占用CPU过高;
  2. ps H -eo pid, tid, %CPU | grep 进程id,定位到该进程中哪个线程占用CPU过高;
  3. jstack 进程id,会打印进程当前线程的堆栈信息,可以根据占用CPU高的线程id进一步定位到源代码的某文件-某行存在问题。
案例2:长时间没有返回结果(出现死锁)

也可以用jstack 进程id命令,定位到具体哪两个(多个)线程出现死锁。

相关推荐
niceffking7 小时前
JVM 一个对象是否已经死亡?
java·jvm·算法
健康平安的活着9 小时前
JVM 调优篇8 调优案例5- 逃逸分析
jvm
刘大猫.10 小时前
Arthas jvm(查看当前JVM的信息)
jvm·arthas·arthas命令·查看当前jvm的信息
pjx98711 小时前
JVM 字节码与 JIT 编译详解
jvm
guangzhi063311 小时前
JVM堆介绍
jvm
18你磊哥11 小时前
java重点学习-JVM类加载器+垃圾回收
java·jvm
翔云12345613 小时前
Go语言的垃圾回收(GC)机制的迭代和优化历史
java·jvm·golang·gc
Yz987616 小时前
Hadoop里面MapReduce的序列化与Java序列化比较
java·大数据·jvm·hadoop·分布式·mapreduce·big data
pjx98717 小时前
JVM 性能调优与监控
jvm·测试工具
无奇不有 不置可否17 小时前
JVM基础篇学习笔记
java·jvm