JVM性能调优

1、基本概念介绍

方法区  

存储整个Java class文件的信息,类加载器子系统(Class Loader)将会从Java class文件中提取类信息,然后把这些class信息保存到方法区。

堆( Heap)

堆是存储的单位,解决了java数据存储的问题。对象的属性就是数据,放在堆中;对象的方法就是运行逻辑,放在栈中。

Java中每一个应用程序(jar包)都唯一对应着一个JVM的实例,每一个JVM实例又有且仅对应一个堆内存。关键字new出来的对象实例、this指针、数组等都是存储在堆中的,并且这些数据所有应用都会进行线程共享。堆内存由JVM虚拟机垃圾回收器GC自动内存管理机制进行管理。

栈( Stack)

栈是操作系统内核给线程建立起来的存储区域,是运行时的单位,存放类执行时的数据,它具备列队先进后出的特点。栈帧随着方法的生命周期同步,方法结束栈帧也被销毁。

在活动线程中,只有位于栈顶的栈帧才是有效的,称为当前栈帧,与这个栈帧相关联的方法称为当前方法。

本地方法栈

在Java中native关键标注的后就可以用来调用其他语言编写的程序,比如用C/C++编写的本地程序代码,而这些方法就是在本地方法栈中运行的,而不是在Java栈中运行,这一点一定要注意区分。

程序计数器(寄存器)

寄存器与线程是对应的,一个线程必然会对应一个寄存器,是线程私有的,用来存储指向下一条指令的地址,由执行引擎读取下一条指令。寄存器生命周期与线程的生命周期保持一致。

程序记数寄存器:跟踪程序执行的准确位置

堆栈指针寄存器:指示操作栈项

框架寄存器:指向当前执行的环境

变量寄存器:指向当前执行环境中第一个本地变量

2、性能调优详解

调优的适用情况

性能调优包含多个层次,比如:架构调优、代码调优、JVM调优、数据库调优、操作系统调优等。

架构调优和代码调优是JVM调优的基础,其中架构调优是对系统影响最大的。

性能调优基本上按照以下步骤进行:明确优化目标、发现性能瓶颈、性能调优、通过监控及数据统计工具获得数据、确认是否达到目标。

当出现以下情况时,就需要考虑进行JVM调优了:

  • Heap内存(老年代)持续上涨达到设置的最大内存值;
  • Full GC 次数频繁;
  • GC 停顿时间过长(超过1秒);
  • 应用出现OutOfMemory 等内存异常;
  • 应用中有使用本地缓存且占用大量内存空间;
  • 系统吞吐量与响应性能不高或下降。

但是JVM调优是最后的选择,还是尽量要在架构和代码层面优化,也可以说是对服务器配置的最后一次“压榨”。

JVM调优时遵循以下原则:

  • 大多数的Java应用不需要进行JVM优化;
  • 大多数导致GC问题的原因是代码层面的问题导致的(代码层面);
  • 上线之前,应先考虑将机器的JVM参数设置到最优;
  • 减少创建对象的数量(代码层面);
  • 减少使用全局变量和大对象(代码层面);
  • 优先架构调优和代码调优,JVM优化是不得已的手段(代码、架构层面);
  • 分析GC情况优化代码比优化JVM参数更好(代码层面);

如何调优

参数解析:

  • -Xms:初始化堆内存大小,默认为物理内存的1/64(小于1GB)。
  • -Xmx:堆内存最大值,默认(MaxHeapFreeRatio参数可以调整)空余堆内存大于70%时,JVM会减少堆直到-Xms的最小限制。
  • -Xmn:设置年轻代大小。增大年轻代后,将会减小年老代大小。此值对系统性能影响较大,Sun官方推荐配置为整个堆的3/8。
  • -Xss:设置每个线程的栈大小。JDK5.0以后每个线程堆栈大小为1MB,以前每个线程堆栈大小为256K。应根据应用线程所需内存大小进行调整。在相同物理内存下,减小这个值能生成更多的线程。但是操作系统对一个进程内的线程数还是有限制的,不能无限生成,经验值在3000~5000左右。
  • -XX:NewRatio:设置年轻代(包括Eden和两个Survivor区)与年老代的比值(除去持久代)。设置为4,则年轻代与年老代所占比值为1:4,年轻代占整个堆栈的1/5
  • -XX:SurvivorRatio:设置年轻代中Eden区与Survivor区的大小比值。设置为8,则两个Survivor区与一个Eden区的比值为2:8,一个Survivor区占整个年轻代的1/10
  • -XX:PermSize:初始化永久代大小。
  • -XX:MaxPermSize:设置持久代大小。
  • -XX:MaxTenuringThreshold:设置垃圾最大年龄。如果设置为0的话,则年轻代对象不经过Survivor区,直接进入年老代。对于年老代比较多的应用,可以提高效率。如果将此值设置为一个较大值,则年轻代对象会在Survivor区进行多次复制,这样可以增加对象再年轻代的存活时间,增加在年轻代即被回收的概论。

新生代、老生代、永久代的参数,如果不进行指定,虚拟机会自动选择合适的值,同时也会基于系统的开销自动调整。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值