基于arthas排查Java内存问题

简介: 基于arthas排查Java内存问题,准确快速定位线上问题

能帮助解决的问题

  1. 这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception?
  2. 我改的代码为什么没有执行到?难道是我没 commit?分支搞错了?
  3. 遇到问题无法在线上 debug,难道只能通过加日志再重新发布吗?
  4. 线上遇到某个用户的数据处理有问题,但线上同样无法 debug,线下无法重现!
  5. 是否有一个全局视角来查看系统的运行状况?
  6. 有什么办法可以监控到JVM的实时运行状态?
  7. 怎么快速定位应用的热点,生成火焰图?
  8. 怎样直接从JVM内查找某个类的实例?

官方文档

Arthas 用户文档 ‒ Arthas 3.5.4 文档

开始体验

下载jar包

wget https://arthas.aliyun.com/arthas-boot.jar

启动jar包

java -jar arthas-boot.jar --target-ip 0.0.0.0
#可以通过浏览器访问
http://127.0.0.1:8563

arthas-bootArthas的启动程序,它启动后,会列出所有的Java进程,用户可以选择需要诊断的目标进程。

选择要调试的java进程

[INFO] arthas-boot version: 3.5.4
[INFO] Found existing java process, please choose one and input the serial number of the process, eg : 1. Then hit ENTER.
* [1]: 1377 demo-arthas-spring-boot.jar
# 选择1,回车
$ 1 
# 会显示以下信息,说明已经启动成功了
[INFO] Start download arthas from remote server: https://arthas.aliyun.com/download/3.5.4?mirror=aliyun
[INFO] Download arthas success.
[INFO] arthas home: /home/shell/.arthas/lib/3.5.4/arthas
[INFO] Try to attach process 1377
[INFO] Attach process 1377 success.
[INFO] arthas-client connect 0.0.0.0 3658
  ,---.  ,------. ,--------.,--.  ,--.  ,---.   ,---.                           
 /  O  \ |  .--. ''--.  .--'|  '--'  | /  O  \ '   .-'                          
|  .-.  ||  '--'.'   |  |   |  .--.  ||  .-.  |`.  `-.                          
|  | |  ||  |\  \    |  |   |  |  |  ||  | |  |.-'    |                         
`--' `--'`--' '--'   `--'   `--'  `--'`--' `--'`-----'                          
wiki       https://arthas.aliyun.com/doc                                        
tutorials  https://arthas.aliyun.com/doc/arthas-tutorials.html                  
version    3.5.4                                                                
main_class                                                                      
pid        1377                                                                 
time       2021-10-21 14:10:42

查看JVM信息

sysprop

查看所有的System properties信息
  • 可以查单个key

sysprop java.version

  • 设置key值
  • sysprop  testkey testvalue

sysenv

命令可以获取到环境变量

dashboard (常用命令)

命令可以查看当前系统的实时数据面板

q

输入 q 或者 Ctrl+C 可以退出dashboard命令

history

可以查看历史执行指令

Tab键可以帮助开发者补全命令,也可以借助 -h 来提示相关命令的文档介绍

Jad

查看反编译代码jad   com.example.demo.arthas.user.UserController--source-only 只打印出反编译的源代码

Sc

命令可以查找到所有JVM已经加载到的类。 如果搜索的是接口,还会搜索所有的实现类sc javax.servlet.Filter sc -d javax.servlet.Filter  可以打印类的具体信息Sc *StringUtils 支持通配

Sm

sm命令则是查找类的具体函数sm java.math.RoundingModesm -d java.math.RoundingMode 通过 -d参数可以打印函数的具体属性:sm java.math.RoundingMode  

Ognl

可以动态执行代码Ognl '@java.lang.System@out.println("hello ognl")'更多用法参考文档

reset

Arthas在 watch/trace 等命令时,实际上是修改了应用的字节码,插入增强的代码显式执行 reset 命令,可以清除掉这些增强代码。

exit

exit 或者 quit 命令可以退出Arthas。

Stop

彻底退出Arthas

thread

Thead 查看所有线程信息Thread 16 查找线程ID为16的栈Thread -n 3 查看CPU使用率top n的栈Thead -b 查找线程是否有阻塞

排查问题案例

RTT问题

curl http://127.0.0.1:9093/goods/listAllGoods?goodsType=2

查看GoodsServiceImpl listAllGoods方法执行耗时

trace  com.findqu.ms.test.GoodsServiceImpl listAllGoods

从日志可以看出来

com.findqu.ms.test.GoodsServiceImpl:listAllGoods()耗时较多,可以重点去排查问题

异常问题

curl http://localhost:61000/user/0
{"timestamp":1550223186170,"status":500,"error":"Internal Server Error","exception":"java.lang.IllegalArgumentException","message":"id < 1","path":"/user/0"}

查看UserController的 参数/异常

watch com.example.demo.arthas.user.UserController * '{params, throwExp}'watch com.example.demo.arthas.user.UserController * '{params, throwExp}' -x 2  如果想把获取到的结果展开,可以用 -x参数

目录
相关文章
|
4天前
|
存储 Java
深入理解Java虚拟机:JVM内存模型
【4月更文挑战第30天】本文将详细解析Java虚拟机(JVM)的内存模型,包括堆、栈、方法区等部分,并探讨它们在Java程序运行过程中的作用。通过对JVM内存模型的深入理解,可以帮助我们更好地编写高效的Java代码,避免内存溢出等问题。
|
4天前
|
算法 Java Go
Go vs Java:内存管理与垃圾回收机制对比
对比了Go和Java的内存管理与垃圾回收机制。Java依赖JVM自动管理内存,使用堆栈内存并采用多种垃圾回收算法,如标记-清除和分代收集。Go则提供更多的手动控制,内存分配与释放由分配器和垃圾回收器协同完成,使用三色标记算法并发回收。示例展示了Java中对象自动创建和销毁,而Go中开发者需注意内存泄漏。选择语言应根据项目需求和技术栈来决定。
|
2天前
|
移动开发 前端开发 JavaScript
Java和web前端,IT新人该如何选择?,2024年最新Web前端内存优化面试
Java和web前端,IT新人该如何选择?,2024年最新Web前端内存优化面试
|
3天前
|
存储 算法 Java
Java一分钟之-Java内存模型与垃圾回收机制概览
【5月更文挑战第16天】本文简述Java内存模型(JMM)和垃圾回收(GC)机制。JMM包括栈、堆、方法区、程序计数器和本地方法栈。GC负责回收不再使用的对象内存,常用算法有新生代、老年代和全堆GC。文章讨论了内存溢出、死锁和GC性能等问题,提出了解决方案,如调整JVM参数和优化GC策略。此外,还强调了避免内存泄漏、大对象管理及正确释放资源的重要性。理解这些概念有助于提升Java应用的性能和稳定性。
13 1
|
4天前
|
Java Linux Arthas
linux上如何排查JVM内存过高?
linux上如何排查JVM内存过高?
552 0
|
4天前
|
存储 算法 Java
了解Java内存管理与垃圾回收机制
了解Java内存管理与垃圾回收机制
8 0
|
4天前
|
存储 机器学习/深度学习 Java
【Java探索之旅】数组使用 初探JVM内存布局
【Java探索之旅】数组使用 初探JVM内存布局
28 0
|
4天前
|
Java 开发者
【JAVA】Java内存模型中的happen-before
Happen-before关系帮助开发者理解多线程程序中操作的执行顺序和可见性,从而避免竞态条件和数据不一致性问题。它提供了一种可预测的规则来确保线程之间的正确交互。
28 0
|
4天前
|
存储 缓存 安全
深入理解Java内存模型及其作用
深入理解Java内存模型及其作用
|
4天前
|
运维 Kubernetes 算法
Java堆内存又溢出了!教你一招必杀技
Java堆内存又溢出了!教你一招必杀技