诊断工具--arthas使用教程

摘要:
这里只是一些常见的使用场景。熟悉Arthas后,可以探索更多的使用场景。要反编译的Jar:Jar类以完整路径退出arthas:您可以使用quit或exit命令。完全退出arthas并执行stop命令。此时,我们可以使用Arthas+Remote远程调用方法。远程工具远程是一个xdebug工具。它具有链接远程服务代码的强大功能,但必须确保本地代码与远程服务器代码一致。
1.背景

 Arthas 是 Alibaba 在 2018 年 9 月开源的 Java 诊断 工具。

2.解决问题

得益于 Arthas 强大且丰富的功能,让 Arthas 能做的事情超乎想象。下面仅仅列举几项常见的使用情况,更多的使用场景可以在熟悉了 Arthas 之后自行探索。

  1. 是否有一个全局视角来查看系统的运行状况?
  2. 为什么 CPU 又升高了,到底是哪里占用了 CPU ?
  3. 运行的多线程有死锁吗?有阻塞吗?
  4. 程序运行耗时很长,是哪里耗时比较长呢?如何监测呢?
  5. 这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception?
  6. 我改的代码为什么没有执行到?难道是我没 commit?分支搞错了?
  7. 遇到问题无法在线上 debug,难道只能通过加日志再重新发布吗?
  8. 有什么办法可以监控到 JVM 的实时运行状态?
3.常用命令

cls: 清屏命令

dashboard会展示当前进程的信息,包含了进程信息,堆栈信息,系统信息,jdk版本信息;退出命令: ctrl+c可以中断执行。

诊断工具--arthas使用教程第1张

jad来反编译: jad  类全路径

 诊断工具--arthas使用教程第2张

退出arthas: 可以用 quit 或者 exit 命令。完全退出arthas,可以执行 stop 命令。

 

4.常见问题使用

1. 远程联调:在日常开发中,我们在联调阶段,发现在我们程序代码上没有任何异常,但是就是结果不对。一定是程序没有按照我们编写流程走。由于某些场景有难以复现,所以调试很麻烦。此刻我们可以使用 Arthas + Remote 远程调用方式。

 Remote工具

remote是一个xdebug工具,它有一个强大的功能,就是链接远程服务代码,但是一定要保证本地代码和远程服务器代码一致。如此强大的功能却有一个致命的问题,稍后在说。

诊断工具--arthas使用教程第3张

诊断工具--arthas使用教程第4张

 具体做法:https://blog.csdn.net/lbh199466/article/details/105661739

缺点:

  a. 未知问题:

引用

https://arthas.aliyun.com/doc/spring-boot-starter.html

免责声明:文章转载自《诊断工具--arthas使用教程》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇小程序动态获取元素高度报错VM14689:1 thirdScriptError Cannot read property 'height' of null;at SelectorQuery callback function TypeError: Cannot read property 'height' of null【spring】jdbcTemplate之sql参数注入下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

Linux及ArmLinux程序开发笔记(零基础入门篇)

Linux及Arm-Linux程序开发笔记(零基础入门篇)  作者:一点一滴的Beerhttp://beer.cnblogs.com/ 本文地址:http://www.cnblogs.com/beer/archive/2011/05/05/2037449.html 目录 一、Arm-Linux程序开发平台简要介绍... 3 1.1程序开发所需系统及开发...

linux top 命令

top 命令主要用于查看进程的相关信息,同时它也会提供系统平均负载,cpu 信息和内存信息。下面的截图展示了 top 命令默认提供的信息: 系统平均负载top 命令输出中的第一行是系统的平均负载,这和 uptime 命令的输出是一样的: 13:05:49      表示系统当前时间。up 7 days    表示系统最后一次启动后总的运行时间。1 us...

Docker 常用命令与操作

介绍 此命令集合版本为 1.11.1 及以上 基础类 查看docker信息 # 查看docker版本 docker version # 显示docker系统的信息 docker info # 日志信息 docker logs # 故障检查 service docker status # 启动关闭docker sudo service d...

linux概念之内存分析

linux内存总结 分析样本[root@221-comecs ~]# free total used freeshared buffers cached Mem: 1019820 782912 236908 0 54104 60...

java之jar命令详解

  1. JAR 文件包   JAR 文件就是 Java Archive File,顾名思意,它的应用是与 Java 息息相关的,是 Java 的一种文档格式。JAR 文件非常类似 ZIP 文件——准确的说,它就是 ZIP 文件,所以叫它文件包。JAR 文件与 ZIP 文件唯一的区别就是在 JAR 文件的内容中,包含了一个 META-INF/MANIFES...

linux性能评估-内存案例实战篇

1.内存泄漏,该如何定位和处理 2.内存中的Buffer 和 Cache 在不同场景下的使用情况 场景 1:磁盘和文件写案例 场景 2:磁盘和文件读案例 1.内存泄漏,该如何定位和处理 机器配置:2 CPU,4GB 内存 预先安装 sysstat、Docker 以及 bcc 软件包,比如: # install sysstat docker s...