jstat工具特别强大,有众多的可选项,详细查看堆内各个部分的使用量,以及加载类的数量。使用时,需加上查看进程的进程id,和所选参数。java
执行:cd $JAVA_HOME/bin中执行jstat,注意jstat后必定要跟参数。算法
各个参数的意义。 工具
如:[root@localhost bin]# jstat -gcutil 25332 1000 10 (25332是java的进程号,ps -ef | grep java)spa
分代概念:对象
分代是Java垃圾收集的一大亮点,根据对象的生命周期长短,把堆分为3个代:Young,Old和Permanent,根据不一样代的特色采用不一样的收集算法,扬长避短也。生命周期
Young(Nursery),年轻代。研究代表大部分对象都是朝生暮死,随生随灭的。所以全部收集器都为年轻代选择了复制算法。进程
复制算法优势是只访问活跃对象,缺点是复制成本高。由于年轻代只有少许的对象能熬到垃圾收集,所以只需少许的复制成本。并且复制收集器只访问活跃对象,对那些占了最大比率的死对象视而不见,充分发挥了它遍历空间成本低的优势。内存
Young(年轻代)ci
年 轻代分三个区。一个Eden区,两个Survivor区。大部分对象在Eden区中生成。当Eden区满时,还存活的对象将被复制到Survivor区 (两个中的一个),当这个Survivor区满时,此区的存活对象将被复制到另一个Survivor区,当这个Survivor去也满了的时候,从第一 个Survivor区复制过来的而且此时还存活的对象,将被复制“年老区(Tenured)”。须要注意,Survivor的两个区是对称的,没前后关 系,因此同一个区中可能同时存在从Eden复制过来 对象,和从前一个Survivor复制过来的对象,而复制到年老区的只有从第一个Survivor去过来的对象。并且,Survivor区总有一个是空 的。it
Tenured(年老代)
年老代存放从年轻代存活的对象。通常来讲年老代存放的都是生命期较长的对象。
Perm(持久代)
用 于存放静态文件,现在Java类、方法等。持久代对垃圾回收没有显著影响,可是有些应用可能动态生成或者调用一些class,例如Hibernate等, 在这种时候须要设置一个比较大的持久代空间来存放这些运行过程当中新增的类。持久代大小经过-XX:MaxPermSize=进行设置。
Gc的基本概念
gc分为full gc 跟 minor gc,当每一块区满的时候都会引起gc。
Scavenge GC
通常状况下,当新对象生成,而且在Eden申请空间失败时,就触发了Scavenge GC,堆Eden区域进行GC,清除非存活对象,而且把尚且存活的对象移动到Survivor区。而后整理Survivor的两个区。
Full GC
对整个堆进行整理,包括Young、Tenured和Perm。Full GC比Scavenge GC要慢,所以应该尽量减小Full GC。有以下缘由可能致使Full GC:
Tenured被写满
Perm域被写满
System.gc()被显示调用
上一次GC以后Heap的各域分配策略动态变化