JVM内存参数调优大展神威

一、栈的大小缺省为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等编程技术的技巧经验分享),若作品对您有帮助,请关注、分享、点赞、收藏、在看、喜欢,您的支持是我们为您提供帮助的最大动力。

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

  • 35
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值