JVM
2021-09-19 16:00:36 27 举报
JVM
作者其他创作
大纲/内容
性能调优
修改
堆-Xms-Xmx
c=30
方法区(元空间)常量+静态变量+类信息
java Math.class
年轻代
user
OOM
动态链接
字节码执行引擎
程序计数器=10
Full GC
本地方法栈
a=1
类装载子系统
math
compute() - 栈帧
JVM虚拟机
关于元空间的JVM参数有两个:-XX:MetaspaceSize=N和 -XX:MaxMetaspaceSize=N-XX:MaxMetaspaceSize: 设置元空间最大值, 默认是-1, 即不限制, 或者说只受限于本地内存大小。-XX:MetaspaceSize: 指定元空间触发Fullgc的初始阈值(元空间无固定初始大小), 以字节为单位,默认是21M,达到该值就会触发full gc进行类型卸载, 同时收集器会对该值进行调整: 如果释放了大量的空间, 就适当降低该值; 如果释放了很少的空间, 那么在不超过-XX:MaxMetaspaceSize(如果设置了的话) 的情况下, 适当提高该值。这个跟早期jdk版本的-XX:PermSize参数意思不一样,-XX:PermSize代表永久代的初始容量。由于调整元空间的大小需要Full GC,这是非常昂贵的操作,如果应用在启动的时候发生大量Full GC,通常都是由于永久代或元空间发生了大小调整,基于这种情况,一般建议在JVM参数中将MetaspaceSize和MaxMetaspaceSize设置成一样的值,并设置得比初始值要大,对于8G物理内存的机器来说,一般我会将这两个值都设置为256M。
堆
类加载
栈(线程2)-Xss
Surviver区
new 对象
栈(线程1)-Xss
Minor GC
s1(1/10)
栈(线程)
FIFO 栈(线程)
新生代-Xmn
监控工具
执行
程序计数器
方法出口
方法区-XX:MetaspaceSize-XX:MaxMetaspaceSize
栈内存分配
垃圾回收
执行引擎
老年代(2/3)
math.class
JVM自身优化技术
局部变量表
直接内存
运行时数据区域(内存模型)JDK8
Eden(8/10)
栈
main线程
this
推荐参数设置java ‐Xms2048M ‐Xmx2048M ‐Xmn1024M ‐Xss512K ‐XX:MetaspaceSize=256M ‐XX:MaxMetaspaceSize=256M ‐jar microservice‐eureka‐server.jar
局部变量
类文件结构
start
操作数栈
s0(1/10)
main() - 栈帧
b=2
STW
内存结构
线程2
0 条评论
下一页