JVM内存参数调优大展神威

程序员小迷 2024-04-29 13:59:22

一、栈的大小缺省为1M,可用参数 –Xss调整大小,例如-Xss256k

二、虚拟机加载的类信息,方法信息,常量(例如"abc","123"等),静态变量(static变量)等数据的存储配置:

1.jdk1.7及以前存储在方法区/永久代:

-XX:PermSize=256m

-XX:MaxPermSize=512m

2.jdk1.8以后存储在元空间Metaspace(放置在堆中):

-XX:MetaspaceSize=800m

-XX:MaxMetaspaceSize=1024m

jdk1.8以后理论最大大小只受本机总内存的限制。

三、堆

堆分为新生代(Eden空间、From Survivor空间、To Survivor空间)、老年代(Tenured Generation空间)。

可以通过-XX:NewRatio、-XX:SurvivorRatio选项来配置年轻代和老年代的比例以及Survivor空间的比例。

Java垃圾回收机制只作用于堆区,对非堆区没有作用。

-Xms100m:堆的最小值

-Xmx900m:堆的最大值

-Xmn200m:新生代的大小(一种简写,代表对下面2个参数同时配置)

-XX:NewSize=300m;新生代堆空间的默认值

-XX:MaxNewSize=800m:新生代堆空间最大值

-XX:NewRatio:一个整数,表示老年代和新生代的比值。例如,若 -XX:NewRatio=3,则新生代占整个堆的1/4,老年代占3/4。

-XX:SurvivorRatio:一个整数,用于指定新生代中Eden区域与Survivor区域的比值。例如,若-XX:SurvivorRatio=8,则一个Survivor区域的大小将是Eden区域大小的1/8。

四、直接内存

直接内存不是java虚拟机规范中定义的内存区域。如果使用了NIO,那么直接内存会被使用。

直接内存是由java.nio包中的ByteBuffer.allocateDirect()方法分配的内存,这块内存不受java堆大小限制,但受本机总内存的限制,所以也会出现OOM(Out Of Memory)内存溢出异常,可以通过-XX:MaxDirectMemorySize来设置(默认与堆内存最大值一样)。

-XX:MaxDirectMemorySize=512m

五、代码缓存

代码缓存是即时编译器JIT编译的热点方法的机器码,可以提高JVM性能。

1)-XX:ReservedCodeCacheSize=400m

JVM分配给代码缓存的总大小。

2)-XX:InitialCodeCacheSize=200m

JVM分配给代码缓存的初始大小。

微风不燥,阳光正好,你就像风一样经过这里,愿你停留的片刻温暖舒心。

我是程序员小迷(致力于C、C++、Java、Kotlin、Android、Shell、JavaScript、TypeScript、Python等编程技术的技巧经验分享),若作品对您有帮助,请关注、分享、点赞、收藏、在看、喜欢,您的支持是我们为您提供帮助的最大动力。

欢迎关注。助您在编程路上越走越好!

0 阅读:35