成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

JVM調優總結:分代垃圾回收詳述

開發 后端
虛擬機中的共劃分為三個代:年輕代、年老點和持久代。其中持久代主要存放的是Java類的類信息,與垃圾收集要收集的Java對象關系不大。年輕代和年老代的劃分是對垃圾收集影響比較大的。下文將進行分代垃圾回收詳述。

為什么要分代

分代的垃圾回收策略,是基于這樣一個事實:不同的對象的生命周期是不一樣的。因此,不同生命周期的對象可以采取不同的收集方式,以便提高回收效率。

在Java程序運行的過程中,會產生大量的對象,其中有些對象是與業務信息相關,比如Http請求中的Session對象、線程、Socket連接,這類對象跟業務直接掛鉤,因此生命周期比較長。但是還有一些對象,主要是程序運行過程中生成的臨時變量,這些對象生命周期會比較短,比如:String對象,由于其不變類的特性,系統會產生大量的這些對象,有些對象甚至只用一次即可回收。

試想,在不進行對象存活時間區分的情況下,每次垃圾回收都是對整個堆空間進行回收,花費時間相對會長,同時,因為每次回收都需要遍歷所有存活對象,但實際上,對于生命周期長的對象而言,這種遍歷是沒有效果的,因為可能進行了很多次遍歷,但是他們依舊存在。因此,分代垃圾回收采用分治的思想,進行代的劃分,把不同生命周期的對象放在不同代上,不同代上采用最適合它的垃圾回收方式進行回收。

如何分代

如圖所示:

虛擬機中的共劃分為三個代:年輕代(Young Generation)、年老點(Old Generation)和持久代(Permanent Generation)。其中持久代主要存放的是Java類的類信息,與垃圾收集要收集的Java對象關系不大。年輕代和年老代的劃分是對垃圾收集影響比較大的。

年輕代:

所有新生成的對象首先都是放在年輕代的。年輕代的目標就是盡可能快速的收集掉那些生命周期短的對象。年輕代分三個區。一個Eden區,兩個Survivor區(一般而言)。大部分對象在Eden區中生成。當Eden區滿時,還存活的對象將被復制到Survivor區(兩個中的一個),當這個Survivor區滿時,此區的存活對象將被復制到另外一個Survivor區,當這個Survivor去也滿了的時候,從***個Survivor區復制過來的并且此時還存活的對象,將被復制“年老區(Tenured)”。需要注意,Survivor的兩個區是對稱的,沒先后關系,所以同一個區中可能同時存在從Eden復制過來 對象,和從前一個Survivor復制過來的對象,而復制到年老區的只有從***個Survivor去過來的對象。而且,Survivor區總有一個是空的。同時,根據程序需要,Survivor區是可以配置為多個的(多于兩個),這樣可以增加對象在年輕代中的存在時間,減少被放到年老代的可能。

年老代:

在年輕代中經歷了N次垃圾回收后仍然存活的對象,就會被放到年老代中。因此,可以認為年老代中存放的都是一些生命周期較長的對象。

持久代:

用于存放靜態文件,如今Java類、方法等。持久代對垃圾回收沒有顯著影響,但是有些應用可能動態生成或者調用一些class,例如Hibernate等,在這種時候需要設置一個比較大的持久代空間來存放這些運行過程中新增的類。持久代大小通過-XX:MaxPermSize=<N>進行設置。

什么情況下觸發垃圾回收

由于對象進行了分代處理,因此垃圾回收區域、時間也不一樣。GC有兩種類型:Scavenge GC和Full GC。

Scavenge GC

一般情況下,當新對象生成,并且在Eden申請空間失敗時,就會觸發Scavenge GC,對Eden區域進行GC,清除非存活對象,并且把尚且存活的對象移動到Survivor區。然后整理Survivor的兩個區。這種方式的GC是對年輕代的Eden區進行,不會影響到年老代。因為大部分對象都是從Eden區開始的,同時Eden區不會分配的很大,所以Eden區的GC會頻繁進行。因而,一般在這里需要使用速度快、效率高的算法,使Eden去能盡快空閑出來。

Full GC

對整個堆進行整理,包括Young、Tenured和Perm。Full GC因為需要對整個對進行回收,所以比Scavenge GC要慢,因此應該盡可能減少Full GC的次數。在對JVM調優的過程中,很大一部分工作就是對于FullGC的調節。有如下原因可能導致Full GC:

 年老代(Tenured)被寫滿

持久代(Perm)被寫滿

System.gc()被顯示調用

上一次GC之后Heap的各域分配策略動態變化

分代垃圾回收流程示意

 

 

 

 

選擇合適的垃圾收集算法

串行收集器

用單線程處理所有垃圾回收工作,因為無需多線程交互,所以效率比較高。但是,也無法使用多處理器的優勢,所以此收集器適合單處理器機器。當然,此收集器也可以用在小數據量(100M左右)情況下的多處理器機器上。可以使用-XX:+UseSerialGC打開。

并行收集器

對年輕代進行并行垃圾回收,因此可以減少垃圾回收時間。一般在多線程多處理器機器上使用。使用-XX:+UseParallelGC.打開。并行收集器在J2SE5.0第六6更新上引入,在Java SE6.0中進行了增強--可以對年老代進行并行收集。如果年老代不使用并發收集的話,默認是使用單線程進行垃圾回收,因此會制約擴展能力。使用-XX:+UseParallelOldGC打開。

使用-XX:ParallelGCThreads=<N>設置并行垃圾回收的線程數。此值可以設置與機器處理器數量相等。

此收集器可以進行如下配置:
 

***垃圾回收暫停:指定垃圾回收時的最長暫停時間,通過-XX:MaxGCPauseMillis=<N>指定。<N>為毫秒.如果指定了此值的話,堆大小和垃圾回收相關參數會進行調整以達到指定值。設定此值可能會減少應用的吞吐量。

吞吐量:吞吐量為垃圾回收時間與非垃圾回收時間的比值,通過-XX:GCTimeRatio=<N>來設定,公式為1/(1+N)。例如,-XX:GCTimeRatio=19時,表示5%的時間用于垃圾回收。默認情況為99,即1%的時間用于垃圾回收。

并發收集器

可以保證大部分工作都并發進行(應用不停止),垃圾回收只暫停很少的時間,此收集器適合對響應時間要求比較高的中、大規模應用。使用-XX:+UseConcMarkSweepGC打開。

并發收集器主要減少年老代的暫停時間,他在應用不停止的情況下使用獨立的垃圾回收線程,跟蹤可達對象。在每個年老代垃圾回收周期中,在收集初期并發收集器 會對整個應用進行簡短的暫停,在收集中還會再暫停一次。第二次暫停會比***次稍長,在此過程中多個線程同時進行垃圾回收工作。

并發收集器使用處理器換來短暫的停頓時間。在一個N個處理器的系統上,并發收集部分使用K/N個可用處理器進行回收,一般情況下1<=K<=N/4。

在只有一個處理器的主機上使用并發收集器,設置為incremental mode模式也可獲得較短的停頓時間。

浮動垃圾:由于在應用運行的同時進行垃圾回收,所以有些垃圾可能在垃圾回收進行完成時產生,這樣就造成了“Floating Garbage”,這些垃圾需要在下次垃圾回收周期時才能回收掉。所以,并發收集器一般需要20%的預留空間用于這些浮動垃圾。

Concurrent Mode Failure:并發收集器在應用運行時進行收集,所以需要保證堆在垃圾回收的這段時間有足夠的空間供程序使用,否則,垃圾回收還未完成,堆空間先滿了。這種情況下將會發生“并發模式失敗”,此時整個應用將會暫停,進行垃圾回收。

啟動并發收集器:因為并發收集在應用運行時進行收集,所以必須保證收集完成之前有足夠的內存空間供程序使用,否則會出現“Concurrent Mode Failure”。通過設置-XX:CMSInitiatingOccupancyFraction=<N>指定還有多少剩余堆時開始執行并發收集。

小  結

串行處理器

◆  適用情況:數據量比較小(100M左右);單處理器下并且對響應時間無要求的應用。

◆ 缺點:只能用于小型應用。

并行處理器:

◆ 適用情況:“對吞吐量有高要求”,多CPU、對應用響應時間無要求的中、大型應用。舉例:后臺處理、科學計算。
◆ 缺點:垃圾收集過程中應用響應時間可能加長。

并發處理器:

◆ 適用情況:“對響應時間有高要求”,多CPU、對應用響應時間有較高要求的中、大型應用。舉例:Web服務器/應用服務器、電信交換、集成開發環境。

原文鏈接:http://pengjiaheng.iteye.com/blog/524024

【編輯推薦】

  1. JVM調優總結:垃圾回收面臨的問題
  2. JVM調優總結:垃圾回收面臨的問題
  3. JVM調優總結:基本垃圾回收算法
  4. JVM調優總結:一些概念
  5. 一個Java程序員對2011年的回顧
責任編輯:林師授 來源: 和你在一起的博客
相關推薦

2012-01-09 16:53:36

JavaJVM

2012-01-10 14:25:36

JavaJVM

2012-01-09 17:06:16

JavaJVM

2017-04-25 14:39:55

JVM內存Java

2021-11-05 15:23:20

JVM回收算法

2010-09-27 09:01:26

JVM分代垃圾回收

2010-09-26 11:22:22

JVM垃圾回收JVM

2011-12-05 12:51:58

JVMJava

2010-01-06 09:28:08

JVM分代垃圾回收

2015-07-06 10:14:25

Java垃圾回收實戰

2012-01-10 14:35:08

JavaJVM

2021-02-04 10:43:52

開發技能代碼

2014-12-19 11:07:40

Java

2010-01-14 11:28:54

JVM分代垃圾回收

2012-01-10 15:13:56

JavaJVM

2010-09-26 13:29:46

JVM垃圾回收

2010-09-25 13:05:07

JVM參數

2017-08-04 10:53:30

回收算法JVM垃圾回收器

2022-01-20 10:34:49

JVM垃圾回收算法

2012-01-10 14:18:40

JavaJVM
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 精品国产精品三级精品av网址 | 欧美国产精品一区二区三区 | 免费观看日韩av | 精品国产乱码久久久久久88av | 欧美一级在线视频 | 五月婷婷丁香 | 成人免费观看男女羞羞视频 | 日韩 国产 在线 | 亚洲精品日韩欧美 | 欧美在线观看一区 | 亚洲色图综合网 | 999国产精品视频免费 | 亚洲精品亚洲人成人网 | 久久一区二区视频 | 成年人网站在线观看视频 | 国产一区在线免费 | 久久久久久亚洲精品 | 国产亚洲欧美日韩精品一区二区三区 | 精品伊人| 久久精品中文字幕 | 欧美三级在线 | 久久精品亚洲 | 狠狠色香婷婷久久亚洲精品 | 欧美久久天堂 | 久久成人精品一区二区三区 | 99热这里只有精品8 激情毛片 | 三区四区在线观看 | 亚洲第一天堂 | 特黄特黄a级毛片免费专区 av网站免费在线观看 | 欧美高清视频在线观看 | 免费九九视频 | 久久久久久国产精品久久 | 福利视频网 | 国产欧美精品 | 日韩三区在线观看 | 亚洲午夜电影 | 亚洲综合无码一区二区 | 欧美日韩综合 | 亚洲精品一区二区三区在线 | 91免费在线看 | 欧美日韩精品影院 |