DirectBuffer的釋放探究

個(gè)人認(rèn)為rocket兩個(gè)核心技術(shù)一個(gè)是網(wǎng)絡(luò)io涕俗,一個(gè)是文件io材鹦〉看到MappedByteBuffer的時(shí)候?qū)?nèi)存映射的釋放邏輯產(chǎn)生了疑惑

基礎(chǔ)知識(shí)

  • java中mmap過程如下,最終的mappedByteBuffer實(shí)際是一個(gè)DirectByteBuffer對象
        File file = new File("xxx");
        FileChannel fileChannel = new RandomAccessFile(file, "rw").getChannel();
        MappedByteBuffer mappedByteBuffer = fileChannel.map(MapMode.READ_WRITE, 0, 4096);

  • 看一下DirectByteBuffer構(gòu)建源碼缓待,可以看到每一個(gè)DirectByteBuffer都會(huì)包含一個(gè)Cleaner實(shí)例(視圖viewer沒有)
image.png
  • Cleaner里面是利用的虛引用蚓耽,當(dāng)DirectByteBuffer對象被垃圾回收時(shí),會(huì)調(diào)用構(gòu)造Cleaner時(shí)傳入的回調(diào)方法旋炒,對MappedByteBuffer來說就是執(zhí)行unmap步悠,具體邏輯在FileChannelImpl的內(nèi)部類Unmapper。對普通DirectByteBuffer來說就是Deallocator中的unsafe.freeMemory()

所以根據(jù)Cleaner的工作原理就能夠理解瘫镇,為什么網(wǎng)上那么多資料說直接內(nèi)存會(huì)隨著gc被回收鼎兽,有些人甚至在需要主動(dòng)回收直接內(nèi)存時(shí)直接調(diào)用System.gc()

  • 當(dāng)我們想要主動(dòng)釋放內(nèi)存映射時(shí),最簡單的辦法就是直接調(diào)用((DirectBuffer) mappedByteBuffer).cleaner().clean()

進(jìn)階部分

  • 后來了解到Cleaner類在java9前后的包是不一樣的铣除,所以如果代碼里持有Cleaner的對象谚咬,就不能在所有jdk中編譯了,當(dāng)然直接調(diào)用((DirectBuffer) mappedByteBuffer).cleaner().clean()肯定沒有問題
java9前:sun.misc.Cleaner
java9后:java.lang.ref.Cleaner
  • 聯(lián)想到netty是直接內(nèi)存使用大戶尚粘,看下netty中的做法序宦。netty中有兩個(gè)類CleanerJava6、CleanerJava9對應(yīng)不同的jdk版本分別使用

CleanerJava6根據(jù)jdk是否有Unsafe類決定通過Unsafe方法還是反射,調(diào)用DirectByteBuffer中Cleaner屬性的clean()方法

image.png

CleanerJava9直接通過反射調(diào)用Unsafe的invokeCleaner()方法(invokeCleaner在java9后才有)互捌,內(nèi)部也是調(diào)用的DirectByteBuffer中Cleaner屬性的clean()方法

image.png

rocket中的做法

  • 在rocket中unmap的邏輯如下潘明,也是通過反射調(diào)用clean()方法,和我之前就關(guān)注的一個(gè)同學(xué)的博客做法完全一致秕噪,希望以后面基 :)
image.png

疑惑思考

  • 為啥大家都非要用反射來調(diào)用clean呢钳降?((DirectBuffer) mappedByteBuffer).cleaner().clean()簡單粗暴不香嗎?還有就是viewed()方法中的viewedBuffer是什么腌巾,沒看到有這個(gè)名字的方法八焯睢?

相當(dāng)于用hotspot編譯之后再openjdk上運(yùn)行澈蝙,就會(huì)報(bào)錯(cuò) https://stackoverflow.com/questions/54323645/apache-spark-method-not-found-sun-nio-ch-directbuffer-cleanerlsun-misc-cleaner

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末吓坚,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子灯荧,更是在濱河造成了極大的恐慌礁击,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,888評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件逗载,死亡現(xiàn)場離奇詭異哆窿,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)厉斟,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,677評論 3 399
  • 文/潘曉璐 我一進(jìn)店門挚躯,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人擦秽,你說我怎么就攤上這事码荔。” “怎么了感挥?”我有些...
    開封第一講書人閱讀 168,386評論 0 360
  • 文/不壞的土叔 我叫張陵目胡,是天一觀的道長。 經(jīng)常有香客問我链快,道長誉己,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,726評論 1 297
  • 正文 為了忘掉前任域蜗,我火速辦了婚禮巨双,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘霉祸。我一直安慰自己筑累,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,729評論 6 397
  • 文/花漫 我一把揭開白布丝蹭。 她就那樣靜靜地躺著慢宗,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上镜沽,一...
    開封第一講書人閱讀 52,337評論 1 310
  • 那天敏晤,我揣著相機(jī)與錄音,去河邊找鬼缅茉。 笑死嘴脾,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的蔬墩。 我是一名探鬼主播译打,決...
    沈念sama閱讀 40,902評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼拇颅!你這毒婦竟也來了奏司?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,807評論 0 276
  • 序言:老撾萬榮一對情侶失蹤樟插,失蹤者是張志新(化名)和其女友劉穎韵洋,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體岸夯,經(jīng)...
    沈念sama閱讀 46,349評論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,439評論 3 340
  • 正文 我和宋清朗相戀三年们妥,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了猜扮。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,567評論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡监婶,死狀恐怖旅赢,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情惑惶,我是刑警寧澤煮盼,帶...
    沈念sama閱讀 36,242評論 5 350
  • 正文 年R本政府宣布,位于F島的核電站带污,受9級特大地震影響僵控,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜鱼冀,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,933評論 3 334
  • 文/蒙蒙 一报破、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧千绪,春花似錦充易、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,420評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春稿静,著一層夾襖步出監(jiān)牢的瞬間梭冠,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,531評論 1 272
  • 我被黑心中介騙來泰國打工自赔, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留妈嘹,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,995評論 3 377
  • 正文 我出身青樓绍妨,卻偏偏與公主長得像润脸,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子他去,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,585評論 2 359

推薦閱讀更多精彩內(nèi)容