Arthas内存泄露排查

Arthas开源的Java 诊断工具,无需重启、无需修改代码,即可:

  • 查看 JVM 状态(线程、内存、GC)
  • 动态追踪方法调用(入参、返回值、异常)
  • 监控对象实例数量
  • 生成堆转储(heap dump)
  • 反编译线上 class
  • 执行 OGNL 表达式操作对象

下载安装:

bash 复制代码
curl -O https://arthas.aliyun.com/arthas-boot.jar

java -jar arthas-boot.jar

核心命令

类别 命令 用途
基础 help 查看帮助
version 查看版本
quit / exit 退出
stop 完全退出并 detach
JVM 信息 dashboard 实时仪表盘
memory 内存使用详情
thread 查看线程
sysprop 查看/设置系统属性
sysenv 查看环境变量
类 & 方法 sc 搜索类
sm 搜索方法
jad 反编译 class
mc + redefine 热更新 class
监控 & 追踪 watch 监控方法入参/返回值/异常
trace 方法调用路径耗时分析
monitor 方法调用统计
tt 时间隧道
内存诊断 vmtool 获取 JVM 中对象实例
ognl 执行 OGNL 表达式
heapdump 生成堆转储
其他 logger 查看/修改日志级别
perfcounter 查看 JVM 性能计数器

常用命令:

  • 查看CPU飙高的线程:
bash 复制代码
thread -n 3
thread <tid>
  • 动态修改日志级别(无需重启)
bash 复制代码
logger
logger --name ROOT --level DEBUG
  • 监控方法 QPS 和异常
bash 复制代码
monitor com.yourcompany.WebSocketHandler channelRead0 -c 5
  • 执行任意Java表达式
bash 复制代码
# 调用静态方法
ognl '@java.lang.System@currentTimeMillis()'

#获取 classloader hash
sc -d com.example.YourClass
# 调用实例方法
ognl -c 18b4aac2 '@com.example.Cache@getInstance().size()'

下面以排查WebSocket堆外内存泄露问题举例:

经排查,怀疑 是WebSocket 消息未释放导致内存增长。

  1. 确认类是否存在

sc io.netty.handler.codec.http.websocketx.TextWebSocketFrame

  1. 查看当前存活实例数

vmtool --action getInstances --className io.netty.handler.codec.http.websocketx.TextWebSocketFrame --limit 1000 | wc -l

  1. 查看实例内容

​vmtool --action getInstances --className io.netty.handler.codec.http.websocketx.TextWebSocketFrame --limit 1 --express 'instances[0].text()'

  1. 追踪其创建对象

watch io.netty.handler.codec.http.websocketx.TextWebSocketFrame <init> '{params, returnObj}' -x 3

  1. 检查 Netty Direct Memory 使用

ognl '@io.netty.buffer.PooledByteBufAllocator@DEFAULT.metric().usedDirectMemory()'

  1. 生成 heap dump(用于 MAT 分析)

heapdump /tmp/websocket-leak.hprof

相关推荐
永远不会的CC2 分钟前
浙江华昱欣实习(4月23日~ 4月19日)
后端·学习
二哈赛车手2 分钟前
新人笔记---实现简易版的rag的bm25检索(利用ES),以及RAG上传时的ES与向量数据库双写
java·数据库·笔记·spring·elasticsearch·ai
winner88815 分钟前
从零吃透C++命名空间、std、#include、string、vector
java·开发语言·c++
AI人工智能+电脑小能手14 分钟前
【大白话说Java面试题】【Java基础篇】第26题:Java的抽象类和接口有哪些区别
java·开发语言·面试
bzmK1DTbd23 分钟前
SOLID原则在Java中的实践:单一职责与开闭原则
java·开发语言·开闭原则
winner888127 分钟前
C++ 命名空间、虚函数、抽象类、protected 权限全套通俗易懂精讲(附与 Java 对比)
java·开发语言·c++
直奔標竿38 分钟前
Java开发者AI转型第二十五课!Spring AI 个人知识库实战(四)——RAG来源追溯落地,拒绝AI幻觉
java·开发语言·人工智能·spring boot·后端·spring
嘟嘟MD39 分钟前
程序员副业 | 2026年4月复盘
后端·创业
时空系1 小时前
认识Rust——我的第一个程序 Rust中文编程
开发语言·后端·rust
qq_589568101 小时前
java基础学习,案例练习,即时通讯
java·开发语言·学习