什么是Metaspace的壓縮類(lèi)空間碳想?

在64位平臺(tái)上,hotspot使用稱(chēng)為壓縮對(duì)象指針(“CompressedOops”)和壓縮類(lèi)指針的優(yōu)化技術(shù)川陆。兩者都是同一事物的變體剂习。

壓縮指針是一種引用數(shù)據(jù)(Java堆中的對(duì)象或元空間中的類(lèi)元數(shù)據(jù))的方法,即使在64位平臺(tái)上也使用32位引用较沪。

這有許多優(yōu)點(diǎn)鳞绕,例如指針大小更小,從而減少內(nèi)存占用和更好地利用緩存购对,并且在某些平臺(tái)上可以使用更多的寄存器猾昆。

Note: A good explanation of Compressed Object Pointers can be found here: JVM Anatomy Quark #23: Compressed References.

Also, a similar motivation drives the Linux x32 abi.

因?yàn)樽罱K一個(gè)人需要一個(gè)64位的地址來(lái)訪問(wèn)那個(gè)東西,那個(gè)32位的“指針”實(shí)際上是一個(gè)偏移量——可能是位移位——進(jìn)入一個(gè)具有已知公共基的區(qū)域骡苞。

關(guān)于Metaspace垂蜗,我們不關(guān)心壓縮的oop,但必須處理壓縮類(lèi)指針:

每個(gè)Java對(duì)象的頭中都有一個(gè)對(duì)Metaspace中Java堆之外的本機(jī)結(jié)構(gòu)的引用:Class結(jié)構(gòu)解幽。

什么是metaspace的壓縮類(lèi)空間贴见?

使用壓縮類(lèi)指針時(shí),該引用是32位值躲株。為了找到該結(jié)構(gòu)的真正64位地址片部,我們向其添加一個(gè)已知的公共基,并可能將值左移三位:

什么是metaspace的壓縮類(lèi)空間霜定?

該技術(shù)對(duì)如何分配這些Klass結(jié)構(gòu)設(shè)置了技術(shù)限制:

Klass結(jié)構(gòu)的每個(gè)可能的位置必須在4G(非移位模式)| 32G(移位模式)的范圍內(nèi)档悠,以從公共基址1的32位偏移量可到達(dá)。

這兩個(gè)限制意味著我們需要將元空間分配為一個(gè)連續(xù)的區(qū)域望浩。

當(dāng)通過(guò)malloc(3)mmap(3)這樣的系統(tǒng)API從系統(tǒng)分配內(nèi)存時(shí)辖所,地址由系統(tǒng)選擇,并且可以是適合類(lèi)型范圍的任何值磨德。因此缘回,在64位平臺(tái)上吆视,當(dāng)然不能保證后續(xù)分配會(huì)在范圍限制內(nèi)產(chǎn)生地址。E酥宴、 g.一個(gè)mmap(3)調(diào)用可以映射到0x0000000700000000啦吧,一個(gè)映射到0x0000000f0000000。

因此拙寡,我們必須使用一個(gè)mmap()調(diào)用來(lái)建立Klass對(duì)象的區(qū)域授滓。因此,我們需要預(yù)先知道這個(gè)區(qū)域的大小倒庵,它不能大于32G褒墨,也永遠(yuǎn)不能可靠地?cái)U(kuò)展炫刷,因?yàn)槌銎淠┒说牡刂贩秶赡芤呀?jīng)被占用擎宝。

這些限制是嚴(yán)厲的。它們也只是真正需要用于Klass結(jié)構(gòu)浑玛,而不是用于其他類(lèi)元數(shù)據(jù):目前只有Klass實(shí)例被壓縮引用處理绍申。因此,可以將其他64位指針?lè)旁谌魏挝恢谩?/p>

因此決定將元空間分成兩部分:“非類(lèi)部分”和“類(lèi)部分”:

  • 等級(jí)部分顾彰,包括Class結(jié)構(gòu)极阅,必須分配為一個(gè)不大于32G的連續(xù)區(qū)域。
  • 包含其他所有內(nèi)容的非類(lèi)部分則沒(méi)有涨享。

Terminology: The class part is called “Compressed Class Space” even though that is a bit of a misnomer since the Klass structures themselves are not compressed but the pointers to them.

壓縮類(lèi)空間的大小由-XX:CompressedClassSpaceSize決定筋搏。因?yàn)槲覀冃枰A(yù)先知道類(lèi)空間的大小,所以該參數(shù)不能為空厕隧。如果省略奔脐,則默認(rèn)為1GB。

更令人困惑的是吁讨,hotspot人為地將classspacesize壓縮到3G的最大值——我真的不知道為什么髓迎。因此,除了32G的技術(shù)限制之外建丧,我們還人為地設(shè)置了3G的限制排龄。

另外請(qǐng)注意,我們一直在談?wù)撎摂M尺寸翎朱,而不是漫畫(huà)尺寸橄维。這種記憶只有在需要的時(shí)候才會(huì)提交。非常簡(jiǎn)化拴曲,虛擬大小在大多數(shù)現(xiàn)代操作系統(tǒng)上幾乎不需要任何成本争舞,它只是一個(gè)addres空間預(yù)留。

由于Klass結(jié)構(gòu)的平均大小為1K疗韵,一個(gè)默認(rèn)大小為1G的壓縮類(lèi)空間將能夠容納大約一百萬(wàn)個(gè)Klass結(jié)構(gòu)(參見(jiàn)調(diào)整元空間大卸艺稀)。這是我們可以加載的類(lèi)數(shù)量的唯一實(shí)際限制。

還請(qǐng)注意流译,當(dāng)我們不使用CompressedOops運(yùn)行時(shí)逞怨,compressedClasspointer將被禁用。如果我們通過(guò)-XX:-CompressedOops手動(dòng)關(guān)閉CompressedOops福澡,或者Java堆大于或等于32G叠赦,就會(huì)發(fā)生這種情況。

往期參考:http://javakk.com/160.html

Implementation

為了重用現(xiàn)有的元空間實(shí)現(xiàn)革砸,采用了一個(gè)技巧:

全局結(jié)構(gòu)VirtualSpaceList和ChunkManager都是重復(fù)的除秀,現(xiàn)在存在于兩個(gè)變體中,“類(lèi)空間”變量和“非類(lèi)空間”變量算利。

但是由于類(lèi)空間需要一個(gè)連續(xù)的地址范圍册踩,我們不能真正使用映射區(qū)域鏈;因此類(lèi)空間列表退化了:它只包含一個(gè)節(jié)點(diǎn)效拭,不能增長(zhǎng)暂吉。與非類(lèi)列表中的同類(lèi)節(jié)點(diǎn)相比,這個(gè)節(jié)點(diǎn)是巨大的缎患。這個(gè)節(jié)點(diǎn)就是壓縮的類(lèi)空間慕的。

什么是metaspace的壓縮類(lèi)空間?
什么是metaspace的壓縮類(lèi)空間挤渔?

ClassLoaderMetaspace——每個(gè)類(lèi)裝入器結(jié)構(gòu)都包含使用這個(gè)類(lèi)裝入器的塊——現(xiàn)在需要兩個(gè)鏈接的塊列表肮街,一個(gè)用于保存非類(lèi)塊,另一個(gè)用于類(lèi)塊判导。這也意味著我們將當(dāng)前節(jié)點(diǎn)的“空閑”部分加倍嫉父,因?yàn)楝F(xiàn)在我們有兩個(gè)節(jié)點(diǎn)。

開(kāi)關(guān):UseCompressedClassPointers骡楼、UseCompressedOops

  • -XX:+UseCompressedOops啟用壓縮對(duì)象指針熔号。

  • -XX:+UseCompressedClassPointers啟用壓縮類(lèi)指針。

默認(rèn)情況下鸟整,兩者都處于打開(kāi)狀態(tài)引镊,但可以手動(dòng)關(guān)閉。

如果壓縮類(lèi)指針被關(guān)閉篮条,我們將沒(méi)有壓縮的類(lèi)空間弟头,并且-XX:CompressedClassSpaceSize開(kāi)關(guān)將被忽略。

-XX:+UseCompressedClassPointers需要-XX:+useCompressedDoops涉茧,但反之亦然:可以在沒(méi)有壓縮類(lèi)指針的情況下運(yùn)行壓縮oops赴恨。這可能有助于在一些病態(tài)的角落案例中減少元空間內(nèi)存占用。一般來(lái)說(shuō)伴栓,建議不要使用這些開(kāi)關(guān)伦连。

注意雨饺,壓縮對(duì)象指針需要Java堆<32G。因此惑淳,如果Java堆>=32G额港,壓縮oop將被關(guān)閉,這也將關(guān)閉壓縮類(lèi)指針歧焦。

文章來(lái)源:http://javakk.com/405.html
也歡迎大家關(guān)注我的公眾號(hào)【Java老K】獲取更多干貨

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末移斩,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子绢馍,更是在濱河造成了極大的恐慌向瓷,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,252評(píng)論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件舰涌,死亡現(xiàn)場(chǎng)離奇詭異猖任,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)舵稠,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,886評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門(mén)超升,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)入宦,“玉大人哺徊,你說(shuō)我怎么就攤上這事∏颍” “怎么了落追?”我有些...
    開(kāi)封第一講書(shū)人閱讀 168,814評(píng)論 0 361
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)涯肩。 經(jīng)常有香客問(wèn)我轿钠,道長(zhǎng),這世上最難降的妖魔是什么病苗? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 59,869評(píng)論 1 299
  • 正文 為了忘掉前任疗垛,我火速辦了婚禮,結(jié)果婚禮上硫朦,老公的妹妹穿的比我還像新娘贷腕。我一直安慰自己,他們只是感情好咬展,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,888評(píng)論 6 398
  • 文/花漫 我一把揭開(kāi)白布泽裳。 她就那樣靜靜地躺著,像睡著了一般破婆。 火紅的嫁衣襯著肌膚如雪涮总。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 52,475評(píng)論 1 312
  • 那天祷舀,我揣著相機(jī)與錄音瀑梗,去河邊找鬼烹笔。 笑死,一個(gè)胖子當(dāng)著我的面吹牛抛丽,可吹牛的內(nèi)容都是我干的箕宙。 我是一名探鬼主播,決...
    沈念sama閱讀 41,010評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼铺纽,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼柬帕!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起狡门,我...
    開(kāi)封第一講書(shū)人閱讀 39,924評(píng)論 0 277
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤陷寝,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后其馏,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體凤跑,經(jīng)...
    沈念sama閱讀 46,469評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,552評(píng)論 3 342
  • 正文 我和宋清朗相戀三年叛复,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了仔引。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,680評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡褐奥,死狀恐怖咖耘,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情撬码,我是刑警寧澤儿倒,帶...
    沈念sama閱讀 36,362評(píng)論 5 351
  • 正文 年R本政府宣布,位于F島的核電站呜笑,受9級(jí)特大地震影響夫否,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜叫胁,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,037評(píng)論 3 335
  • 文/蒙蒙 一凰慈、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧驼鹅,春花似錦微谓、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,519評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至张足,卻和暖如春触创,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背为牍。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,621評(píng)論 1 274
  • 我被黑心中介騙來(lái)泰國(guó)打工哼绑, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留岩馍,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,099評(píng)論 3 378
  • 正文 我出身青樓抖韩,卻偏偏與公主長(zhǎng)得像蛀恩,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子茂浮,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,691評(píng)論 2 361