arthas排查内存溢出
时间: 2023-07-25 14:10:02 浏览: 191
arthas是一款非常强大的Java诊断工具,可以用来排查各种问题,包括内存溢出。下面是使用arthas排查内存溢出的一些步骤:
1. 查看JVM内存使用情况
可以使用arthas的`jvm`命令来查看JVM内存使用情况,包括堆内存、非堆内存、GC情况等等。例如,输入`jvm`命令后,可以看到如下信息:
```
$ jvm
JVMSummary
--------------------------------------------------------------------------------
PID : 12345
StartTime : 2020-01-01 00:00:00
UpTime : 1h
JvmArgs : -Xms256m -Xmx1024m -XX:PermSize=64m -XX:MaxPermSize=256m -Djava.awt.headless=true -Dfile.encoding=UTF-8
OS : Linux 4.4.0-18362-Microsoft #1-Microsoft Wed Mar 06 19:16:00 PST 2019 x86_64
Arch : amd64
Processors : 8
JvmVersion : 1.8.0_281-b09
--------------------------------------------------------------------------------
HeapMemory
init:1073741824(1024.00MB), used:553289024(527.03MB), committed:1073741824(1024.00MB), max:1073741824(1024.00MB)
NonHeapMemory
init:2555904(2.44MB), used:51789232(49.38MB), committed:55050240(52.5MB), max:-1(-1.00MB)
GC
PS Scavenge count=0, time=0ms
PS MarkSweep count=2, time=84ms
```
其中,HeapMemory表示堆内存使用情况,NonHeapMemory表示非堆内存使用情况,GC表示垃圾回收情况。
2. 查看当前内存中的对象
可以使用arthas的`heapdump`命令来生成当前内存中的对象快照。例如,输入`heapdump`命令后,会在当前目录下生成一个`.hprof`文件,然后可以使用一些工具来分析这个文件,比如MAT(Memory Analyzer Tool)。MAT可以用来分析内存快照,查看内存泄漏等问题。
3. 查看对象的引用关系
如果已经确定了内存泄漏的对象,可以使用arthas的`jmap`命令来查看该对象的引用关系。例如,输入`jmap -histo:live <object_id>`命令后,可以看到该对象被哪些其他对象引用,从而找到内存泄漏的原因。
4. 查看内存泄漏位置
可以使用arthas的`trace`命令来查看程序执行过程中的方法调用情况,从而找到内存泄漏的位置。例如,输入`trace com.example.demo.* traceTarget`命令后,可以查看com.example.demo包下的所有类的方法调用情况,并定位到内存泄漏的位置。
以上就是使用arthas排查内存溢出的一些步骤,希望对你有所帮助。
阅读全文