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

相关推荐
好家伙VCC2 小时前
# 发散创新:用 Rust构建高性能游戏日系统,从零实现事件驱动架构 在现代游戏开发中,**性能与可扩展性**是核心命题。传统基于
java·python·游戏·架构·rust
爱笑的源码基地2 小时前
门诊his系统源码,中西医结合的数字化门诊解决方案
java·spring boot·源码·二次开发·门诊系统·云诊所系统·诊所软件源码
庞轩px2 小时前
缓存Key设计的“七要七不要”
java·jvm·redis·缓存
小璐资源网2 小时前
Java 21 新特性实战:虚拟线程详解
java·开发语言·python
SimonKing3 小时前
全网爆火的OpenClaw保姆级教程Linux版,它来了。
java·后端·程序员
于慨3 小时前
tauri
java·服务器·前端
WZTTMoon3 小时前
从互斥锁到无锁,Java 20年并发安全进化史
java·python·安全
青柠代码录3 小时前
【Linux】常用命令:sort
后端
2501_918126913 小时前
学习所有6502写游戏控制器的语句
java·linux·网络·汇编·嵌入式硬件
青春易逝丶3 小时前
策略模式
java·开发语言·策略模式