排查Java應(yīng)用內(nèi)存泄漏問(wèn)題的步驟
什么是內(nèi)存泄漏
內(nèi)存泄漏是指java應(yīng)用的堆內(nèi)存使用率持續(xù)升高,直至內(nèi)存溢出。
內(nèi)存泄漏的的原因可能有多種
- 分配給應(yīng)用程序的內(nèi)存本身過(guò)小。而應(yīng)用的業(yè)務(wù)代碼,確實(shí)需要生成大量的對(duì)象
- 代碼bug,某些需要被回收的對(duì)象,由于代碼bug,卻持續(xù)的被引用,導(dǎo)致java虛擬機(jī)無(wú)法回收這些對(duì)象。從而撐爆內(nèi)存
無(wú)論哪種內(nèi)存泄露,我們的解決方法都是要定位到具體是什么對(duì)象,占用了大量?jī)?nèi)存,從而方便我們基于此進(jìn)行代碼分析,debug,找出代碼問(wèn)題。
而能夠幫助我們實(shí)現(xiàn)這一目的的方式就是獲取java應(yīng)用的內(nèi)存 dump
如何獲取內(nèi)存dump
使用命令獲取jcmd
首先需要獲取java 進(jìn)程id,獲取到j(luò)ava進(jìn)程后
使用命令
jcmd <pid> GC.heap_dump <file-path>
如果執(zhí)行報(bào)錯(cuò)
com.sun.tools.attach.AttachNotSupportedException: Unable to open socket file: target process not responding or HotSpot VM not loaded
一般是由于執(zhí)行jcmd的用戶同java應(yīng)用本身不是同一個(gè)用戶。解決辦法是切換到應(yīng)用對(duì)應(yīng)的用戶下再執(zhí)行上述命令
sudo -u [userid] /jcmd <pid> GC.heap_dump <file-path>
如果應(yīng)用在本地
如果應(yīng)用是在本地,除了用上述方法外,還可以用JVisualVM 、JConsole
程序異常退出時(shí)自動(dòng)dump
但更為重要的,為了準(zhǔn)確還原應(yīng)用故障的現(xiàn)場(chǎng),最好通過(guò)指定java 執(zhí)行參數(shù),在程序出錯(cuò)時(shí),自動(dòng)dump
java -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=<file-or-dir-path>
如何分析內(nèi)存dump
獲取到dump文件后,需要使用eclipse.org 出品的 Memory Analyzer 工具。使用其中的Dominator Tree,查看各對(duì)象的內(nèi)存占用情況

找出占用內(nèi)存最多的對(duì)象及其類信息

以上就是排查Java應(yīng)用內(nèi)存泄漏問(wèn)題的步驟的詳細(xì)內(nèi)容,更多關(guān)于Java應(yīng)用內(nèi)存泄漏的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- Java基礎(chǔ)詳解之內(nèi)存泄漏
- Java中的內(nèi)存泄漏
- Java內(nèi)部類的實(shí)現(xiàn)原理與可能的內(nèi)存泄漏說(shuō)明
- macOS上使用gperftools定位Java內(nèi)存泄漏問(wèn)題及解決方案
- Java虛擬機(jī)內(nèi)存溢出與內(nèi)存泄漏
- 簡(jiǎn)單了解JAVA內(nèi)存泄漏和溢出區(qū)別及聯(lián)系
- java內(nèi)存泄漏與內(nèi)存溢出關(guān)系解析
- 一次 Java 內(nèi)存泄漏的排查解決過(guò)程詳解
- Java基礎(chǔ)之堆內(nèi)存溢出的解決
- Java 內(nèi)存溢出的原因和解決方法
- Java虛擬機(jī)常見內(nèi)存溢出錯(cuò)誤匯總
- JAVA 內(nèi)存溢出案例匯總
- Java內(nèi)存溢出實(shí)現(xiàn)原因及解決方案
- JAVA內(nèi)存溢出解決方案圖解
- Java基礎(chǔ)之內(nèi)存泄漏與溢出詳解
相關(guān)文章
Java利用Netty時(shí)間輪實(shí)現(xiàn)延時(shí)任務(wù)
時(shí)間輪是一種可以執(zhí)行定時(shí)任務(wù)的數(shù)據(jù)結(jié)構(gòu)和算法。本文將為大家詳細(xì)講解一下Java如何利用Netty時(shí)間輪算法實(shí)現(xiàn)延時(shí)任務(wù),感興趣的小伙伴可以了解一下2022-08-08
Mybatis傳單個(gè)參數(shù)和<if>標(biāo)簽同時(shí)使用的問(wèn)題及解決方法
這篇文章主要介紹了Mybatis傳單個(gè)參數(shù)和<if>標(biāo)簽同時(shí)使用的問(wèn)題及解決方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-05-05
詳談fastjson將對(duì)象格式化成json時(shí)的兩個(gè)問(wèn)題
下面小編就為大家?guī)?lái)一篇詳談fastjson將對(duì)象格式化成json時(shí)的兩個(gè)問(wèn)題。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-05-05
springboot中@PostConstruct注解使用小結(jié)
本文主要介紹了springboot中@PostConstruct注解使用小結(jié),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2025-01-01
Java?Process中waitFor()的問(wèn)題詳解
這篇文章主要給大家介紹了關(guān)于Java?Process中waitFor()問(wèn)題的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2022-12-12
String split方法實(shí)現(xiàn)過(guò)程圖解
這篇文章主要介紹了String split方法實(shí)現(xiàn)過(guò)程圖解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-11-11

