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

相关推荐
Dicky-_-zhang2 小时前
消息队列Kafka/RocketMQ选型与高可用架构:从单体到100万TPS的演进
java·jvm
2301_781571422 小时前
Golang格式化输出占位符都有什么_Golang fmt占位符教程【通俗】
jvm·数据库·python
Dicky-_-zhang6 小时前
容器编排实战:Docker与Kubernetes对比选型与落地实践
java·jvm
XiYang-DING6 小时前
【Java SE】JVM
java·开发语言·jvm
m0_470857646 小时前
PHP怎么实现工厂模式_Factory模式编写指南【指南】
jvm·数据库·python
Dicky-_-zhang7 小时前
日志管理实战:ELK与Loki对比选型与落地实践
java·jvm
小王C语言7 小时前
【线程概念与控制】:线程封装
jvm·c++·算法
江南十四行8 小时前
并发编程(一)
java·jvm·算法
2301_783848658 小时前
mysql数据库迁移到云平台流程_使用数据传输服务DTS工具
jvm·数据库·python
Dicky-_-zhang8 小时前
自动化运维实战:监控告警与自动化运维的完整方案
java·jvm