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命令,定位到具体哪两个(多个)线程出现死锁。

相关推荐
没有bug.的程序员2 小时前
微服务中的数据一致性困局
java·jvm·微服务·架构·wpf·电商
重生之我是Java开发战士2 小时前
【数据结构】Java对象的比较
java·jvm·数据结构
invicinble19 小时前
jar包在执行的时候需要关注的细节(提供一个解构jvm问题的视角)
java·jvm·jar
Evan芙21 小时前
JVM原理总结
jvm
fei_sun21 小时前
【总结】【OS】成组链接法
jvm·数据结构
7ioik1 天前
JVM 核心参数调优清单
jvm
CodeAmaz1 天前
JVM一次完整GC流程详解
java·jvm·gc流程
笃行客从不躺平1 天前
JVM 类加载机制复习
jvm
飞火流星020271 天前
【Arthas工具】使用Trace命令分析Java JVM方法调用链路及耗时
java·jvm·arthas·jvm性能调优·java方法调用链路分析及耗时·jvm实时分析·jvm方法调用实时分析
7ioik1 天前
JVM 调优工具深度指南:从监控到诊断的全流程实战
jvm