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

相关推荐
killerbasd8 小时前
总结 7.04
jvm
summer_west_fish16 小时前
K8s下Java服务OOM排查指南
jvm
花生了什么事o19 小时前
Java 线程池:从参数到拒绝策略
java·jvm
Esaka_Forever19 小时前
Python 与 JS (V8) 垃圾回收核心区别 + 底层根源分析
开发语言·javascript·jvm
wuminyu19 小时前
markword在高并发场景下变化剖析
java·linux·c语言·jvm·c++
爱奥尼欧20 小时前
轻量级可扩展日志框架-日志落地与日志器模块实现
jvm·数据库·c++
Rotion_深20 小时前
C# 值类型与引用类型 详解
开发语言·jvm·c#
C++、Java和Python的菜鸟1 天前
第1章 集合高级
java·jvm·python
骑士雄师2 天前
java面试题:jvm ,mybatis
java·jvm·mybatis
珊珊而川2 天前
flexsearch静默错误
java·开发语言·jvm