首先须要注意的是在对JVM内存调优的时候不能只看操做系统级别Java进程所占用的内存,这个数值不能准确的反应堆内存的真实占用状况,由于GC事后这个值是不会变化的,所以内存调优的时候要更多地使用JDK提供的内存查看工具,好比JConsole和Java VisualVM。java
对JVM内存的系统级的调优主要的目的是减小GC的频率和Full GC的次数,过多的GC和Full GC是会占用不少的系统资源(主要是CPU),影响系统的吞吐量。特别要关注Full GC,由于它会对整个堆进行整理,致使Full GC通常因为如下几种状况:数组
调优手段主要是经过控制堆内存的各个部分的比例和GC策略来实现,下面来看看各部分比例不良设置会致使什么后果并发
1)新生代设置太小分布式
一是新生代GC次数很是频繁,增大系统消耗;二是致使大对象直接进入旧生代,占据了旧生代剩余空间,诱发Full GC工具
2)新生代设置过大post
一是新生代设置过大会致使旧生代太小(堆总量必定),从而诱发Full GC;二是新生代GC耗时大幅度增长学习
通常说来新生代占整个堆1/3比较合适操作系统
3)Survivor设置太小.net
致使对象从eden直接到达旧生代,下降了在新生代的存活时间线程
4)Survivor设置过大
致使eden太小,增长了GC频率
另外,经过-XX:MaxTenuringThreshold=n来控制新生代存活时间,尽可能让对象在新生代被回收
由上一篇博文JVM学习笔记(三)------内存管理和垃圾回收可知新生代和旧生代都有多种GC策略和组合搭配,选择这些策略对于咱们这些开发人员是个难题,JVM提供两种较为简单的GC策略的设置方式
1)吞吐量优先
JVM以吞吐量为指标,自行选择相应的GC策略及控制新生代与旧生代的大小比例,来达到吞吐量指标。这个值可由-XX:GCTimeRatio=n来设置
2)暂停时间优先
JVM以暂停时间为指标,自行选择相应的GC策略及控制新生代与旧生代的大小比例,尽可能保证每次GC形成的应用中止时间都在指定的数值范围内完成。这个值可由-XX:MaxGCPauseRatio=n来设置
最后汇总一下JVM常见配置
附:
本系列学习资料主要来自博文http://rednaxelafx.javaeye.com/blog/656951里提到的PPT和《分布式Java应用》里有关JVM的章节,推荐你们继续深刻学习
from: http://blog.csdn.NET/cutesource/article/details/5907418