91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

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

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

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

如何使用NMT和pmap來解決JVM的資源泄漏問題

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

掃碼添加小助手

加入工程師交流群

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

背景知識:

NMT

NMT 是 Native Memory Tracking 的縮寫,一個(gè) JDK 自帶的小工具,用來跟蹤 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ù)來開啟:

-XX:NativeMemoryTracking=[summary | detail]

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

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

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

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

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

pmap

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

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

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

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

pYYBAGFNe46AXEijAACM5oGR0ow649.png

現(xiàn)象:

某業(yè)務(wù)集群中,多個(gè)節(jié)點(diǎn)出現(xiàn)業(yè)務(wù)進(jìn)程內(nèi)存消耗緩慢增長現(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)存占用量不超過 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ū)域,但無法監(jiān)控到那些由 JVM 之外的 Native Code 申請的內(nèi)存,例如典型的場景:第三方 so 庫中調(diào)用 malloc 函數(shù)申請一塊內(nèi)存的行為無法被 JVM 感知到。

nmt 除了會展示概覽之外,還會詳細(xì)羅列每一片受 JVM 監(jiān)控的內(nèi)存,包括其地址,將這些 JVM 監(jiān)控到的內(nèi)存布局和用 pmap 得到的完整的進(jìn)程內(nèi)存布局做一個(gè)對比篩查,這里忽略 nmt 和 pmap(下圖 pmap 命令中 25600 是進(jìn)程號)詳細(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)存并不對應(yīng)真正占用的物理內(nèi)存(linux 使用 Lazy 策略管理進(jìn)程內(nèi)存),實(shí)際通常會稍小。

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

由于這個(gè)目錄資源底層是會關(guān)聯(lián)一個(gè) fd 的,所以泄漏問題還可以通過另一個(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)存值基本對上。

總結(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)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • Linux
    +關(guān)注

    關(guān)注

    88

    文章

    11761

    瀏覽量

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

    關(guān)注

    8

    文章

    685

    瀏覽量

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

    關(guān)注

    0

    文章

    161

    瀏覽量

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

    關(guān)注

    0

    文章

    83

    瀏覽量

    17152

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

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

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

掃碼添加小助手

加入工程師交流群

    評論

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

    CANopen協(xié)議核心秘籍:NMT、SDO、PDO、心跳報(bào)文一網(wǎng)打盡

    工程師必備:從狀態(tài)切換、參數(shù)配置到實(shí)時(shí)數(shù)據(jù)傳輸,一篇搞定CANopen通信難題CANopen協(xié)議在工業(yè)自動(dòng)化中無處不在,但復(fù)雜的對象字典、多樣的報(bào)文類型常讓開發(fā)者頭疼。本文將NMT網(wǎng)絡(luò)管理、SDO
    的頭像 發(fā)表于 03-05 19:34 ?68次閱讀
    CANopen協(xié)議核心秘籍:<b class='flag-5'>NMT</b>、SDO、PDO、心跳報(bào)文一網(wǎng)打盡

    Microchip MTCH9010泄漏檢測器助力醫(yī)療設(shè)備安全升級

    在醫(yī)療設(shè)備的安全設(shè)計(jì)中,液體泄漏檢測常常被忽視,但它卻是守護(hù)設(shè)備穩(wěn)定運(yùn)行和患者安全的關(guān)鍵一環(huán)。Microchip的MTCH9010泄漏檢測器,正如專家博文《Microchip的MTCH9010泄漏
    的頭像 發(fā)表于 01-07 16:41 ?529次閱讀

    化工廠液體泄漏識別預(yù)警系統(tǒng)

    化工廠液體泄漏識別預(yù)警系統(tǒng)基于人工智能分析技術(shù),化工廠液體泄漏識別預(yù)警系統(tǒng)自動(dòng)識別監(jiān)控視頻中機(jī)械管道是否存在液體泄漏行為。如檢測到液體泄漏,立即反饋給后臺人員及時(shí)處理?;S液體
    的頭像 發(fā)表于 12-17 18:29 ?332次閱讀
    化工廠液體<b class='flag-5'>泄漏</b>識別預(yù)警系統(tǒng)

    T3400系列制冷劑泄漏檢測傳感器:高效可靠的制冷監(jiān)測方案

    在電子工程師的日常工作中,制冷系統(tǒng)的制冷劑泄漏檢測是一個(gè)關(guān)鍵的設(shè)計(jì)領(lǐng)域。今天,我們深入了解一下Telaire的T3400系列制冷劑泄漏檢測傳感器,看看它有哪些獨(dú)特之處。
    的頭像 發(fā)表于 12-09 15:22 ?497次閱讀
    T3400系列制冷劑<b class='flag-5'>泄漏</b>檢測傳感器:高效可靠的制冷監(jiān)測方案

    便攜氣體探測器:地下燃?xì)夤芫W(wǎng)泄漏的“移動(dòng)哨兵”

    城市地下燃?xì)夤芫W(wǎng)是城市能源輸送的“地下生命線”,維系著千家萬戶的日常需求,但因其隱蔽性強(qiáng)、復(fù)雜性和環(huán)境干擾,泄漏風(fēng)險(xiǎn)始終存在。從施工事故導(dǎo)致的燃?xì)獗?,到設(shè)備老化引發(fā)的持續(xù)泄漏,每一次安全事件都在
    的頭像 發(fā)表于 10-20 08:58 ?418次閱讀
    便攜氣體探測器:地下燃?xì)夤芫W(wǎng)<b class='flag-5'>泄漏</b>的“移動(dòng)哨兵”

    使用w5500通信使用wiz包的時(shí)候,突然拔掉網(wǎng)線,如何釋放網(wǎng)絡(luò)資源

    也就越多。也就是在拔掉網(wǎng)線之后調(diào)用closesocket并沒有釋放網(wǎng)絡(luò)資源。這個(gè)時(shí)候再次接入網(wǎng)線,就無法繼續(xù)通信了。需要重啟w5500。但是重啟w5500也無法解決內(nèi)存泄漏的問題。 有沒有人知道如何解決這個(gè)問題? 這個(gè)是我調(diào)用wiz_reset之后測試的效果
    發(fā)表于 10-11 09:01

    at_device 包 ml307長時(shí)間運(yùn)行有內(nèi)存泄漏問題怎么解決?

    使用 at_device 包中的 ml307 包長時(shí)間運(yùn)行有大量內(nèi)存泄漏問題,大概漲了20K,求助解決。
    發(fā)表于 09-24 07:41

    閥門總是微泄漏?氣密性檢測儀精準(zhǔn)定位問題點(diǎn)-岳信儀器

    在工業(yè)生產(chǎn)的眾多領(lǐng)域中,閥門是極為關(guān)鍵的部件,它掌控著流體的流動(dòng)與停止,對整個(gè)生產(chǎn)流程的穩(wěn)定運(yùn)行起著至關(guān)重要的作用。然而,閥門微泄漏卻是一個(gè)長期困擾著眾多企業(yè)的難題。微小的泄漏不僅會造成資源的浪費(fèi)
    的頭像 發(fā)表于 09-20 11:32 ?357次閱讀
    閥門總是微<b class='flag-5'>泄漏</b>?氣密性檢測儀精準(zhǔn)定位問題點(diǎn)-岳信儀器

    防爆氣體泄漏紅外成像儀LST360采用取景器(OLED)1280*1024像素!讓隱形氣體泄漏無處遁形

    減少了粉塵、二氧化硫等危險(xiǎn)氣體的出現(xiàn),改善了空氣的質(zhì)量。但在使用的過程中,如果管道運(yùn)輸途中出現(xiàn)氣體泄漏會導(dǎo)致生產(chǎn)生活的中斷,造成資源的浪費(fèi),還會埋下安全隱患,這期
    的頭像 發(fā)表于 08-26 17:08 ?790次閱讀
    防爆氣體<b class='flag-5'>泄漏</b>紅外成像儀LST360采用取景器(OLED)1280*1024像素!讓隱形氣體<b class='flag-5'>泄漏</b>無處遁形

    如何通過PinView檢查I/O電流泄漏?

    如何通過PinView檢查I/O電流泄漏?
    發(fā)表于 08-25 07:45

    ArkUI-X資源分類與訪問

    類型(type)和資源名稱(name)引用。| 通過指定資源類型(type)和資源名稱(name)引用。| 通過指定文件路徑和文件名
    發(fā)表于 06-23 22:39

    在OpenVINO? C++代碼中啟用 AddressSanitizer 時(shí)的內(nèi)存泄漏怎么解決?

    在 OpenVINO? C++代碼中啟用 AddressSanitizer 時(shí)遇到內(nèi)存泄漏: \"#0 0xaaaab8558370 in operator new(unsigned
    發(fā)表于 06-23 07:16

    颯特紅外熱成像技術(shù)助力氣體泄漏檢測

    隨著美國、歐洲率先立法,全球各國政府正緊跟其后,策劃實(shí)施LDAR(Leak Detection and Repair,泄漏檢測與修復(fù))法規(guī)以遏制氣體泄漏,主要針對石油煉化廠、化工廠的揮發(fā)性有機(jī)化合物(VOCs)及有害空氣污染物(HAPs)。
    的頭像 發(fā)表于 06-18 10:40 ?1285次閱讀

    快問快答:泄漏等級有哪些?含閥門氣密性檢測原理方法和解決方案

    一、閥門的泄漏等級想象一下,一座化工廠的關(guān)鍵管道上,一個(gè)微小的閥門泄漏可能造成數(shù)百萬的損失甚至安全事故。這就是為什么閥門泄漏等級成為工業(yè)界的「生命線」。閥門的泄漏等級是衡量閥門關(guān)閉嚴(yán)密
    的頭像 發(fā)表于 04-16 11:34 ?4530次閱讀
    快問快答:<b class='flag-5'>泄漏</b>等級有哪些?含閥門氣密性檢測原理方法和解決方案

    推薦兩款菲力爾氣體泄漏檢測神器

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