一胸囱、概述
簡(jiǎn)單的優(yōu)化一下jvm參數(shù)洽瞬,對(duì)應(yīng)用的性能影響還是挺大的,因此隨筆一下對(duì)GC的理解操漠。GC的術(shù)語(yǔ)中有兩個(gè)概念:垃圾回收算法和垃圾收集器收津。
垃圾回收算法:gc算法有很多鐘,但都是為了解決問(wèn)題提高效率而演進(jìn)來(lái)的浊伙,按個(gè)人理解歸納如下:
基本算法:判別活與死的問(wèn)題撞秋,計(jì)數(shù)(對(duì)引用進(jìn)行計(jì)算)和標(biāo)志可達(dá)(對(duì)引用進(jìn)行遍歷)。
引用計(jì)數(shù)——在循環(huán)引用時(shí)嚣鄙,計(jì)數(shù)存豐是死是活的判定問(wèn)題吻贿。
引用可達(dá)標(biāo)志——通過(guò)GC Roots遍歷引用可達(dá)的對(duì)象,被遍歷到的對(duì)象將被標(biāo)志存活哑子。
策略算法:基于“標(biāo)志可達(dá)”算法舅列,已解決了死與活的問(wèn)題,目的是采用一定的策略進(jìn)行有效的回收垃圾赵抢。因此衍生出了3種標(biāo)志可達(dá)的算法:標(biāo)志-清除剧蹂、標(biāo)志-拷貝声功、標(biāo)志-整理
標(biāo)志-清除(Mark-Clean)——簡(jiǎn)單粗暴型烦却,引用不可達(dá)的對(duì)象,直接清除掉先巴,存在內(nèi)存碎片的問(wèn)題其爵。
標(biāo)志-拷貝(Mark-Copy)——奢侈霸氣型(拷貝操作:塊到塊),內(nèi)存一分為二(兩塊)伸蚯,同一時(shí)間只能使用其中的一塊(只能在一塊上申請(qǐng)內(nèi)存)摩渺,該塊滿時(shí)進(jìn)行可達(dá)標(biāo)志,然后把活的對(duì)象拷貝到另一塊(剂邮,該塊就被全部回收了摇幻。周而復(fù)始,兩塊循環(huán)使用挥萌。存在一半的空間浪費(fèi)和永久對(duì)象重復(fù)拷貝的問(wèn)題绰姻。
標(biāo)志-整理(Mark-Sweep)——剛需實(shí)用型(拷貝操作:端到端),內(nèi)存還是一塊引瀑,當(dāng)使用量達(dá)到了某個(gè)閾值時(shí)狂芋,進(jìn)行引用可達(dá)標(biāo)志,把活的對(duì)象從它一端拷貝到一另端憨栽。它雖然改進(jìn)了標(biāo)志-拷貝的算法帜矾,但還是存在部分空間浪費(fèi)和永久對(duì)象重復(fù)拷貝的問(wèn)題翼虫。
戰(zhàn)略算法:為了進(jìn)一步提高效率,還需要從軟布局和硬件上來(lái)使用策略算法屡萤,來(lái)解決性能珍剑、效能和對(duì)象重復(fù)拷貝的問(wèn)題。從軟布局上實(shí)施分代的戰(zhàn)略死陆,進(jìn)行分而治之次慢,便誕生了:新生代、老年代和永久代等內(nèi)存區(qū)域翔曲;從硬件上發(fā)揮多核的威力迫像,便誕生了:串行、并行和并發(fā)等手段瞳遍。因此在新生代上衍生出的GC算法:Serial(新生代串行收集器)闻妓、ParNew(新生代并行收集器)和PS(Parallel Scavenge);在老年代中上衍生出的GC算法:SerialOld掠械、Parallel Old由缆、CMS(ConcurrentMarkSweep);G1收集器在新生代和老年中同時(shí)生效猾蒂。
場(chǎng)景算法:根據(jù)不同的場(chǎng)景均唉,選擇不同的收集器,發(fā)揮最大威力肚菠,有:吞吐量?jī)?yōu)先型(PS舔箭、Parallel Old)和響應(yīng)優(yōu)先型(ParNew、CMS)蚊逢。與用戶直接交互的應(yīng)用一般采用響應(yīng)優(yōu)先型层扶;有異步處理特點(diǎn)的后端服務(wù)應(yīng)用一般采用吞吐量?jī)?yōu)先型。
新生代——又分為1個(gè)Eden區(qū)和兩個(gè)Survivor區(qū)烙荷。因此該代的內(nèi)存回收上都是基于標(biāo)志-拷貝算法的镜会。
老年代——該代的內(nèi)存回收基本上都是基于標(biāo)志-整理算法的
新老代收集器搭配——由于JVM具體實(shí)現(xiàn)問(wèn)題,新生代和老年代各自使用的收集器并不是完全獨(dú)立的终抽,是需要相互兼容搭配的戳表。
收集器搭配使用:
老年代SerialOld ——新生代Serial、ParNew和PS
老年代CMS ——新生代Serial昼伴、ParNew
老年代Parallel Old——新生代PS
因此jvm客戶端(啟動(dòng)參數(shù)中有-client)默認(rèn)采用的就是Serial(新生代)和Serial Old(老年代)匾旭,jvm服務(wù)端(啟動(dòng)參數(shù)中有-server)默認(rèn)采用的就是ParNew(新生代)和Serial Old(老年代)
G1