性能调优 - JVM
因为 Java 虚拟机的核心,主要分为堆、栈、方法区和垃圾回收系统等几个部分构成,因此我们在进行 JVM 调优的时候,主要是针对他们的参数配置和垃圾回收策略选择等的选择,来进行最合适的配置组合。
-Xmx512m
设置 Java虚 拟机的最大堆。整个堆大小 = 年轻代大小 + 年老代大小 + 持久代大小。持久代一般固定大小为64m。堆的不同分布情况,对系统会产生一定的影响。尽可能将对象预留在新生代,减少老年代 GC 的次数(通常老年回收起来比较慢)。实际工作中,通常将堆的初始值和最大值设置相等,这样可以减少程序运行时进行的垃圾回收次数和空间扩展,从而提高程序性能。
-Xms512m
设置 Java 虚拟机的堆的初始值内存大小,一般设置为与
-Xmx
相同,避免每次垃圾回收完成后,JVM 重新进行内存分配。
-Xmn170m
设置年轻代内存大小。此值对系统性能影响较大,官方推荐配置为整个堆的3/8。一般在增大年轻代内存后,也会将会减小年老代大小。
-Xss128k
设置每个线程的栈大小。JDK5.0以后每个线程栈大小为1M,以前每个线程栈大小为256K。更具应用的线程所需内存大小进行调整。在相同物理内存下,减小这个值能生成更多的线程。但是操作系统对一个进程内的线程数还是有限制的,不能无限生成,经验值在3000~5000左右。
-XX:NewRatio=4
设置年轻代(包括Eden和两个Survivor区)与年老代的比值(除去持久代)。设置为4,则年轻代与年老代所占比值为1:4,年轻代占整个堆栈的1/5 。
-XX:SurvivorRatio=4
设置年轻代中Eden区与Survivor区的大小比值。设置为4,则两个Survivor区与一个Eden区的比值为2:4,一个Survivor区占整个年轻代的1/6。
-XX:MaxPermSize=16m
设置持久代大小,一般固定的内存大小为64m。
-XX:MaxTenuringThreshold=0
设置垃圾最大年龄。如果设置为0的话,则年轻代对象不经过Survivor区,直接进入年老代。对于年老代比较多的应用,可以提高效率。如果将此值设置为一个较大值,则年轻代对象会在Survivor区进行多次复制,这样可以增加对象再年轻代的存活时间,增加在年轻代即被回收的概论。