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的各域分配策略動態變化