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

相关推荐
2301_8174973330 分钟前
自然语言处理(NLP)入门:使用NLTK和Spacy
jvm·数据库·python
码农水水40 分钟前
米哈游Java面试被问:Shenandoah GC的Brooks Pointer实现机制
java·开发语言·jvm·spring boot·redis·安全·面试
码农水水1 小时前
大疆Java面试被问:使用Async-profiler进行CPU热点分析和火焰图解读
java·开发语言·jvm·数据结构·后端·面试·职场和发展
hcnaisd21 小时前
使用Python进行PDF文件的处理与操作
jvm·数据库·python
Hello.Reader2 小时前
Flink 进程三种配置方式、JVM 参数映射与常见踩坑
大数据·jvm·flink
yufuu982 小时前
Python数据库操作:SQLAlchemy ORM指南
jvm·数据库·python
忧郁的Mr.Li3 小时前
JVM-类加载子系统、运行时数据区 详解
java·jvm
2301_811232983 小时前
机器学习与人工智能
jvm·数据库·python
2401_832402753 小时前
使用Scikit-learn构建你的第一个机器学习模型
jvm·数据库·python
Y_033 小时前
浅谈Java虚拟机JVM
java·开发语言·jvm