一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

如何使用NMT和pmap來(lái)解決JVM的資源泄漏問(wèn)題

openEuler ? 來(lái)源:openEuler ? 作者:宋堯飛 ? 2021-09-24 16:00 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

編者按:筆者使用 JDK 自帶的內(nèi)存跟蹤工具 NMT 和 Linux 自帶的 pmap 解決了一個(gè)非常典型的資源泄漏問(wèn)題。這個(gè)資源泄漏是由于 Java 程序員不正確地使用 Java API 導(dǎo)致的,使用 Files.list 打開的文件描述符必須關(guān)閉。本案例一方面介紹了怎么使用 NMT 解決 JVM 資源泄漏問(wèn)題,如果讀者遇到類似問(wèn)題,可以嘗試用 NMT 來(lái)解決;另一方面也提醒 Java 開發(fā)人員使用 Java API 時(shí)需要必須弄清楚 API 使用規(guī)范,希望大家通過(guò)這個(gè)案例有所收獲。

背景知識(shí):

NMT

NMT 是 Native Memory Tracking 的縮寫,一個(gè) JDK 自帶的小工具,用來(lái)跟蹤 JVM 本地內(nèi)存分配情況(本地內(nèi)存指的是 non-heap,例如 JVM 在運(yùn)行時(shí)需要分配一些輔助數(shù)據(jù)結(jié)構(gòu)用于自身的運(yùn)行)。

NMT 功能默認(rèn)關(guān)閉,可以在 Java 程序啟動(dòng)參數(shù)中加入以下參數(shù)來(lái)開啟:

-XX:NativeMemoryTracking=[summary | detail]

其中,“summary” 和 “detail” 的差別主要在輸出信息的詳細(xì)程度。

3cb43d90-10ac-11ec-8fb8-12bb97331649.png

開啟 NMT 功能后,就可以使用 JDK 提供的 jcmd 命令來(lái)讀取 NMT 采集的數(shù)據(jù)了,具體命令如下:

jcmd 《pid》 VM.native_memory [summary | detail | baseline | summary.diff | detail.diff | shutdown]

NMT 參數(shù)的含義可以通過(guò) “jcmd 《pid》 help VM.native_memory” 命令查詢。通過(guò) NMT 工具,我們可以快速區(qū)分內(nèi)存泄露是否源自 JVM 分配。

pmap

對(duì)于非 JVM 分配的內(nèi)存,經(jīng)常需要用到 pmap 這個(gè)工具了,這是一個(gè) linux 系統(tǒng)自帶工具,能夠從系統(tǒng)層面輸出目標(biāo)進(jìn)程內(nèi)存使用的詳細(xì)情況,用法非常簡(jiǎn)單:

pmap [參數(shù)] 《pid》

常用的選項(xiàng)是 “-x” 或 “-X”,都是用來(lái)控制輸出信息的詳細(xì)程度。

上圖是 pmap 部分輸出信息,每列含義為

pYYBAGFNe46AXEijAACM5oGR0ow649.png

現(xiàn)象:

某業(yè)務(wù)集群中,多個(gè)節(jié)點(diǎn)出現(xiàn)業(yè)務(wù)進(jìn)程內(nèi)存消耗緩慢增長(zhǎng)現(xiàn)象,以其中一個(gè)節(jié)點(diǎn)為例:

3cd60e48-10ac-11ec-8fb8-12bb97331649.png

如圖所示,這個(gè)業(yè)務(wù)進(jìn)程當(dāng)前占用了 4.7G 的虛擬內(nèi)存空間,以及 2.2G 的物理內(nèi)存。已知正常狀態(tài)下該業(yè)務(wù)進(jìn)程的物理內(nèi)存占用量不超過(guò) 1G。

分析:

使用命令 “jcmdVM.native_memory detail” 可以看到所有受 JVM 監(jiān)控的內(nèi)存分布情況:

3cfaa4e2-10ac-11ec-8fb8-12bb97331649.png

上圖只是截取了 nmt(Native Memory Tracking) 命令展示的概覽信息,這個(gè)業(yè)務(wù)進(jìn)程占用的 2.2G 物理內(nèi)存中,受 JVM 監(jiān)控的大概只占了 0.7G(上圖中的 committed),意味著有 1.5G 物理內(nèi)存不受 JVM 管控。JVM 可以監(jiān)控到 Java 堆、元空間、CodeCache、直接內(nèi)存等區(qū)域,但無(wú)法監(jiān)控到那些由 JVM 之外的 Native Code 申請(qǐng)的內(nèi)存,例如典型的場(chǎng)景:第三方 so 庫(kù)中調(diào)用 malloc 函數(shù)申請(qǐng)一塊內(nèi)存的行為無(wú)法被 JVM 感知到。

nmt 除了會(huì)展示概覽之外,還會(huì)詳細(xì)羅列每一片受 JVM 監(jiān)控的內(nèi)存,包括其地址,將這些 JVM 監(jiān)控到的內(nèi)存布局和用 pmap 得到的完整的進(jìn)程內(nèi)存布局做一個(gè)對(duì)比篩查,這里忽略 nmt 和 pmap(下圖 pmap 命令中 25600 是進(jìn)程號(hào))詳細(xì)內(nèi)存地址的信息,直接給出最可疑的那塊內(nèi)存:

3d0e578a-10ac-11ec-8fb8-12bb97331649.png

由圖可知,這片 1.7G 左右的內(nèi)存區(qū)域?qū)儆谙到y(tǒng)層面的堆區(qū)。

備注:這片系統(tǒng)堆區(qū)之所以稍大于上面計(jì)算得到的差值,原因大概是 nmt 中顯示的 committed 內(nèi)存并不對(duì)應(yīng)真正占用的物理內(nèi)存(linux 使用 Lazy 策略管理進(jìn)程內(nèi)存),實(shí)際通常會(huì)稍小。

系統(tǒng)堆區(qū)主要就是由 libc 庫(kù)接口 malloc 申請(qǐng)的內(nèi)存組合而成,所以接下來(lái)就是去跟蹤業(yè)務(wù)進(jìn)程中的每次 malloc 調(diào)用,可以借助 GDB:

3d235a5e-10ac-11ec-8fb8-12bb97331649.png

實(shí)際上會(huì)有大量的干擾項(xiàng),這些干擾項(xiàng)一方面來(lái)自 JVM 內(nèi)部,比如:

3d3cc782-10ac-11ec-8fb8-12bb97331649.png

這部分干擾項(xiàng)很容易被排除,凡是調(diào)用棧中存在 “os::malloc” 這個(gè)棧幀的干擾項(xiàng)就可以直接忽視,因?yàn)檫@些 malloc 行為都會(huì)被 nmt 監(jiān)控到,而上面已經(jīng)排除了受 JVM 監(jiān)控內(nèi)存泄漏的可能。

另一部分干擾項(xiàng)則來(lái)自 JDK,比如:

3d6b9ee0-10ac-11ec-8fb8-12bb97331649.png

有如上圖所示,不少 JDK 的本地方法中直接或間接調(diào)用了 malloc,這部分 malloc 行為通常是不受 JVM 監(jiān)控的,所以需要根據(jù)具體情況逐個(gè)排查,還是以上圖為例,排查過(guò)程如下:

3dac2b22-10ac-11ec-8fb8-12bb97331649.png

注意圖中臨時(shí)中斷的值(0x0000ffff5fc55d00)來(lái)自于第一個(gè)中斷 b malloc 中斷發(fā)生后的結(jié)果。

這里稍微解釋一下上面 GDB 在做的排查過(guò)程,就是檢查 malloc 返回的內(nèi)存地址后續(xù)是否有通過(guò) free 釋放(通過(guò) tb free if X3 這個(gè)命令,具體用法可以參考 GDB 調(diào)試),顯然在這個(gè)例子中是有釋放的。

通過(guò)這種排查方式,幾經(jīng)篩選,最終找到了一個(gè)可疑的 malloc 場(chǎng)景:

3dbaf18e-10ac-11ec-8fb8-12bb97331649.png

從調(diào)用棧信息可以知道,這是一個(gè) JDK 中的本地方法 sun.nio.fs.UnixNativeDispatcher.opendir0,作用是打開一個(gè)目錄,但后續(xù)始終沒有進(jìn)行關(guān)閉操作。進(jìn)一步分析可知,該可疑 opendir 操作會(huì)周期性執(zhí)行,而且都是操作同一個(gè)目錄 “/xxx/nginx/etc/nginx/conf”,看來(lái),是有個(gè)業(yè)務(wù)線程在定時(shí)訪問(wèn) nginx 的配置目錄,每次訪問(wèn)完卻沒有關(guān)閉打開的目錄。

分析到這里,其實(shí)這個(gè)問(wèn)題已經(jīng)差不多水落石出。和業(yè)務(wù)方確認(rèn),存在一個(gè)定時(shí)器線程在周期性讀取 nginx 的配置文件,代碼大概是這樣子的:

3dfba080-10ac-11ec-8fb8-12bb97331649.png

翻了一下相關(guān) JDK 源碼,F(xiàn)iles.list 方法是有在末尾注冊(cè)一個(gè)關(guān)閉鉤子的:

3e0bb2b8-10ac-11ec-8fb8-12bb97331649.png

也就是說(shuō),F(xiàn)iles.list 方法返回的目錄資源是需要手動(dòng)釋放的,否則就會(huì)發(fā)生資源泄漏。

由于這個(gè)目錄資源底層是會(huì)關(guān)聯(lián)一個(gè) fd 的,所以泄漏問(wèn)題還可以通過(guò)另一個(gè)地方進(jìn)行佐證:

3e3fafaa-10ac-11ec-8fb8-12bb97331649.png

該業(yè)務(wù)進(jìn)程目前已經(jīng)消耗了 51116 個(gè) fd!

假設(shè)這些 fd 都是 opendir 關(guān)聯(lián)的,每個(gè) opendir 消耗 32K,則總共消耗 1.6G,顯然可以跟上面泄漏的內(nèi)存值基本對(duì)上。

總結(jié):

稍微了解了一下,發(fā)現(xiàn)幾乎沒人知道 JDK 方法 Files.list 是需要關(guān)閉的,這個(gè)案例算是給大家都提了個(gè)醒。

編輯:jq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11496

    瀏覽量

    213225
  • 源碼
    +關(guān)注

    關(guān)注

    8

    文章

    669

    瀏覽量

    30240
  • JVM
    JVM
    +關(guān)注

    關(guān)注

    0

    文章

    160

    瀏覽量

    12560
  • JDK
    JDK
    +關(guān)注

    關(guān)注

    0

    文章

    83

    瀏覽量

    16851

原文標(biāo)題:使用 NMT 和 pmap 解決 JVM 資源泄漏問(wèn)題

文章出處:【微信號(hào):openEulercommunity,微信公眾號(hào):openEuler】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    推薦兩款菲力爾氣體泄漏檢測(cè)神器

    在石化行業(yè),氣體泄漏是安全生產(chǎn)的“大敵”。如何快速、精準(zhǔn)地檢測(cè)泄漏,成了企業(yè)關(guān)注的焦點(diǎn)。今天,小菲就帶大家聊聊菲力爾的兩款“氣體泄漏檢測(cè)神器”——FLIR Si2x系列聲學(xué)成像儀和Gx系列光學(xué)氣體成像熱像儀。它們都能“看到”氣體
    的頭像 發(fā)表于 04-07 11:22 ?441次閱讀

    內(nèi)存泄漏檢測(cè)工具Sanitizer介紹

    內(nèi)存泄漏,我們經(jīng)常會(huì)遇到,如何檢測(cè)內(nèi)存泄漏,除了我們之前講過(guò)的 valgrind,還可以使用 gcc 自帶的工具 sanitizer。
    的頭像 發(fā)表于 03-01 14:52 ?667次閱讀

    FLIR OGI熱像儀助力氣體泄漏檢測(cè)

    2005年,F(xiàn)LIR開創(chuàng)性地發(fā)布了首臺(tái)商業(yè)用途OGI熱像儀,20年來(lái),這款革命性產(chǎn)品以卓越的氣體泄漏檢測(cè)能力,持續(xù)引領(lǐng)工業(yè)安全領(lǐng)域的技術(shù)革新,成為眾多行業(yè)信賴的安全守護(hù)神!
    的頭像 發(fā)表于 02-19 17:11 ?624次閱讀

    科普:產(chǎn)品密封泄漏試驗(yàn)等級(jí)評(píng)定標(biāo)準(zhǔn)及方法詳解

    在工業(yè)生產(chǎn)中,產(chǎn)品的密封性直接關(guān)系到其性能、壽命和安全性。密封性泄漏試驗(yàn)作為一項(xiàng)重要的質(zhì)量控制手段,旨在檢測(cè)產(chǎn)品防止氣體或液體泄漏的能力。不同的應(yīng)用場(chǎng)景對(duì)產(chǎn)品的密封性要求不同,因此需要對(duì)泄漏試驗(yàn)進(jìn)行
    的頭像 發(fā)表于 02-06 11:39 ?745次閱讀
    科普:產(chǎn)品密封<b class='flag-5'>泄漏</b>試驗(yàn)等級(jí)評(píng)定標(biāo)準(zhǔn)及方法詳解

    如何利用氣體壓力傳感器監(jiān)測(cè)氣體泄漏

    在化工、石油、天然氣等行業(yè)中,氣體泄漏可能導(dǎo)致嚴(yán)重的安全事故和環(huán)境污染。因此,及時(shí)準(zhǔn)確地監(jiān)測(cè)氣體泄漏對(duì)于保障人員安全和環(huán)境保護(hù)至關(guān)重要。氣體壓力傳感器作為一種有效的監(jiān)測(cè)工具,能夠通過(guò)檢測(cè)壓力變化來(lái)
    的頭像 發(fā)表于 12-09 18:03 ?1139次閱讀

    什么是泄漏電流試驗(yàn)?

    泄漏電流的概念泄漏電流(leakagecurrent)也叫接觸電流,是指在沒有故障施加電壓的情況下,電氣中相互絕緣的金屬零件之間,或帶電零件與接地零件之間,通過(guò)其周圍介質(zhì)或絕緣表面所形成的電流。泄漏
    的頭像 發(fā)表于 11-26 11:48 ?1581次閱讀
    什么是<b class='flag-5'>泄漏</b>電流試驗(yàn)?

    JVM xmx, xms等內(nèi)存相關(guān)參數(shù)合理性設(shè)置

    作者:京東零售 劉樂(lè) 上一篇文章說(shuō)到JVM垃圾回收算法的兩個(gè)優(yōu)化標(biāo)的:吞吐量和停頓時(shí)長(zhǎng),并提到這兩個(gè)優(yōu)化目標(biāo)是有沖突的。那么有沒有可能提高吞吐量而不影響停頓時(shí)長(zhǎng),甚至縮短停頓時(shí)長(zhǎng)呢?答案是有可能
    的頭像 發(fā)表于 10-10 14:42 ?1248次閱讀

    超聲波泄漏檢測(cè)

    電子發(fā)燒友網(wǎng)站提供《超聲波泄漏檢測(cè).pdf》資料免費(fèi)下載
    發(fā)表于 09-02 11:33 ?0次下載
    超聲波<b class='flag-5'>泄漏</b>檢測(cè)

    從原理聊JVM(一):染色標(biāo)記和垃圾回收算法

    導(dǎo)讀 JAVA簡(jiǎn)單易用的特性,能夠讓研發(fā)人員在不了解JVM的底層運(yùn)行機(jī)制的情況下依舊能夠編寫出功能完善的代碼。 但是對(duì)JVM的理解,是一個(gè)程序員普通和優(yōu)秀的分水嶺。全面地了解JVM的工作原理,能夠
    的頭像 發(fā)表于 08-20 15:25 ?489次閱讀
    從原理聊<b class='flag-5'>JVM</b>(一):染色標(biāo)記和垃圾回收算法

    正壓密封試驗(yàn)儀YY/T 0681.5-2010內(nèi)壓法檢測(cè)粗大泄漏(氣泡法)

    正壓密封試驗(yàn)儀YY/T0681.5-2010內(nèi)壓法檢測(cè)粗大泄漏(氣泡法)是一種專門用于評(píng)估無(wú)菌醫(yī)療器械包裝密封性能的測(cè)試方法。該方法通過(guò)向包裝內(nèi)部施加正壓,觀察包裝在水下是否出現(xiàn)連續(xù)的氣泡流,以此來(lái)判斷包裝是否存在粗大泄漏
    的頭像 發(fā)表于 08-19 14:51 ?1576次閱讀
    正壓密封試驗(yàn)儀YY/T 0681.5-2010內(nèi)壓法檢測(cè)粗大<b class='flag-5'>泄漏</b>(氣泡法)

    聊聊JVM如何優(yōu)化

    首先應(yīng)該明確的是JVM調(diào)優(yōu)不是常規(guī)手段,JVM的存在本身就是為了減輕開發(fā)對(duì)于內(nèi)存管理的負(fù)擔(dān),當(dāng)出現(xiàn)性能問(wèn)題的時(shí)候第一時(shí)間考慮的是代碼邏輯與設(shè)計(jì)方案,以及是否達(dá)到依賴中間件的瓶頸,最后才是針對(duì)JVM
    的頭像 發(fā)表于 08-05 17:49 ?737次閱讀
    聊聊<b class='flag-5'>JVM</b>如何優(yōu)化

    如何檢測(cè)內(nèi)存泄漏

    檢測(cè)內(nèi)存泄漏是軟件開發(fā)過(guò)程中一項(xiàng)至關(guān)重要的任務(wù),它有助于識(shí)別和解決那些導(dǎo)致程序占用過(guò)多內(nèi)存資源,從而影響程序性能甚至導(dǎo)致程序崩潰的問(wèn)題。以下將詳細(xì)闡述幾種常見的內(nèi)存泄漏檢測(cè)方法,每種方法都會(huì)結(jié)合具體步驟和工具進(jìn)行說(shuō)明。
    的頭像 發(fā)表于 07-30 11:50 ?3320次閱讀

    包裝泄漏性檢測(cè)方法—真空衰減法

    MLT系列微泄漏無(wú)損密封測(cè)試儀依據(jù)《ASTM F2338-2013 包裝泄漏的標(biāo)準(zhǔn)檢測(cè)方法-真空衰減法》標(biāo)準(zhǔn)研發(fā)。適用于預(yù)充式 注射器、水針及粉針瓶(玻璃/塑料)、灌裝壓蓋瓶、奶粉罐、其他硬質(zhì)
    的頭像 發(fā)表于 07-23 16:51 ?1556次閱讀
    包裝<b class='flag-5'>泄漏</b>性檢測(cè)方法—真空衰減法

    NONOS 1.5.3/1.5.4 SSL內(nèi)存泄漏的原因?

    我已經(jīng)通過(guò)隨附的代碼驗(yàn)證了當(dāng)發(fā)生 SSL 握手錯(cuò)誤時(shí),會(huì)生成內(nèi)存泄漏 此外,espconn_reconnect_callback不稱為信令ESPCONN_HANDSHAKE - TCP SSL 握手
    發(fā)表于 07-18 07:24

    化工廠液體泄漏識(shí)別預(yù)警算法

    化工廠液體泄漏識(shí)別預(yù)警基于圖像識(shí)別算法是計(jì)算機(jī)視覺的基礎(chǔ)算法,例如VGG,GoogLeNet,ResNet等,化工廠液體泄漏識(shí)別這類算法主要是判斷圖片中目標(biāo)的種類液體泄漏識(shí)別預(yù)警自動(dòng)識(shí)別監(jiān)控視頻中機(jī)械管道是否存在液體
    的頭像 發(fā)表于 07-03 08:35 ?838次閱讀
    化工廠液體<b class='flag-5'>泄漏</b>識(shí)別預(yù)警算法