Jvm参数调优一
JVM内存结构:
Java内存模型(多线程JMM)---Java内存结构(JVM虚拟机存储空间)
Java内存结构
方法区(永久区):static关键字修饰、常量信息
当class文件被加载的时候方法区就会被初始化,方法区会被所有线程共享(注意线程安全问题)
调优问题:web开发,定义太多常量不好,影响内存
jvm参数调优:
1、堆内存初始值和堆内存最大值一定要保持一致(减少垃圾回收机制)
2、设置新生代和老年代垃圾回收机制比例
(新生代与老年代比例1:3或者1:4)
堆:new 创建的对象、数组都会存放在堆中
堆内存是所有线程会被共享的
栈:定义的局部变量(代码运行完,自动释放内存)、对象的引用,(类的方法存在栈中)
栈是每个线程私有的,互不共享
本地方法栈:本地方法栈主要调用c语言
如果在s0或者s1中依旧频繁调用,就会将user移到老年代中
调优:
web系统中、尽量减少常量信息(常量信息多、占内存,服务启动变慢)
尽量减少垃圾回收机制的次数(次数越多,影响服务效率)
尽量减少老年代的回收,使新生代回收次数比老年代高
栈溢出:产生的原因是无限递归调用
解决循环栈溢出问题,加最大栈深度