JVM调优

JVM将内存划分为:(经过配置合理的jvm各内存大小)算法

  • New(年轻代)
  • Tenured(年老代)
  • 永久代(Perm)

垃圾回收算法(经过配置合适垃圾回收算法进行调优)服务器

  垃圾回收算法能够分为三类,都基于标记-清除(复制)算法:并发

  • Serial算法(单线程)
  • 并行算法
  • 并发算法

性能调优jvm

对程序及JVM进行调优。从如下几个方面进行:工具

  • 线程池:解决用户响应时间长的问题
  • 链接池
  • JVM启动参数:调整各代的内存比例和垃圾回收算法,提升吞吐量
  • 程序算法:改进程序逻辑算法提升性能

 

调优方法性能

 原则:优化

一、多数的Java应用不须要在服务器上进行GC优化;线程

二、多数致使GC问题的Java应用,都不是由于咱们参数设置错误,而是代码问题;日志

三、在应用上线以前,先考虑将机器的JVM参数设置到最优(最适合);对象

四、减小建立对象的数量;

五、减小使用全局变量和大对象;

六、GC优化是到最后不得已才采用的手段;

七、在实际使用中,分析GC状况优化代码比优化GC参数要多得多;

 

GC优化的目的有两个:

一、将转移到老年代的对象数量下降到最小;

二、减小full GC的执行时间;

 

为了达到上面的目的,通常地,你须要作的事情有:

一、减小使用全局变量和大对象;

二、调整新生代的大小到最合适;

三、设置老年代的大小为最合适;

四、选择合适的GC收集器;

 

在上面的4条方法中,用了几个“合适”,那究竟什么才算合适,通常的,请参考上面“收集器搭配”和“启动内存分配”两节中的建议。但这些建议不是万能的,须要根据您的机器和应用状况进行发展和变化,实际操做中,能够将两台机器分别设置成不一样的GC参数,而且进行对比,选用那些确实提升了性能或减小了GC时间的参数。

 

真正熟练的使用GC调优,是创建在屡次进行GC监控和调优的实战经验上的,进行监控和调优的通常步骤为:

1,监控GC的状态

使用各类JVM工具,查看当前日志,分析当前JVM参数设置,而且分析当前堆内存快照和gc日志,根据实际的各区域内存划分和GC执行时间,以为是否进行优化;

 

2,分析结果,判断是否须要优化

若是各项参数设置合理,系统没有超时日志出现,GC频率不高,GC耗时不高,那么没有必要进行GC优化;若是GC时间超过1-3秒,或者频繁GC,则必须优化;

注:若是知足下面的指标,则通常不须要进行GC:

   Minor GC执行时间不到50ms;

   Minor GC执行不频繁,约10秒一次;

   Full GC执行时间不到1s;

   Full GC执行频率不算频繁,不低于10分钟1次;

 

3,调整GC类型和内存分配

若是内存分配过大或太小,或者采用的GC收集器比较慢,则应该优先调整这些参数,而且先找1台或几台机器进行beta,而后比较优化过的机器和没有优化的机器的性能对比,并有针对性的作出最后选择;

4,不断的分析和调整

经过不断的试验和试错,分析并找到最合适的参数

5,全面应用参数

若是找到了最合适的参数,则将这些参数应用到全部服务器,并进行后续跟踪。

相关文章
相关标签/搜索