arthas诊断器简介

笑着哭i 提交于 2020-12-30 17:54:36

arthas是阿里巴巴开源的JVM诊断利器,当我们遇到以下类似问题而束手无策时,Arthas可以帮助解决:

  • 这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception?
  • 我改的代码为什么没有执行到?难道是我没 commit?分支搞错了?
  • 遇到问题无法在线上 debug,难道只能通过加日志再重新发布吗?
  • 线上遇到某个用户的数据处理有问题,但线上同样无法 debug,线下无法重现!
  • 是否有一个全局视角来查看系统的运行状况?
  • 有什么办法可以监控到JVM的实时运行状态?
  • 怎么快速定位应用的热点,生成火焰图? Arthas支持JDK 6+,支持Linux/Mac/Windows,采用命令行交互模式,同时提供丰富的 Tab 自动补全功能,进一步方便进行问题的定位和诊断。
安装使用
#下载
curl -O https://arthas.aliyun.com/arthas-boot.jar
#运行 方式一
java -jar arthas-boot.jar --telnet-port 9998 --http-port -1
#运行 方式二
java -jar arthas-boot.jar
查看线程
#查看最繁忙的三个线程
thread -n 3
反编译 jad
#查看我们的代码是否发布上去了
jad javax.servlet.Servlet

ClassLoader:
+-java.net.URLClassLoader@6108b2d7
  +-sun.misc.Launcher$AppClassLoader@18b4aac2
    +-sun.misc.Launcher$ExtClassLoader@1ddf84b8

Location:
/Users/xxx/work/test/lib/servlet-api.jar

/*
 * Decompiled with CFR 0_122.
 */
package javax.servlet;

import java.io.IOException;
import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;

public interface Servlet {
    public void init(ServletConfig var1) throws ServletException;

    public ServletConfig getServletConfig();

    public void service(ServletRequest var1, ServletResponse var2) throws ServletException, IOException;

    public String getServletInfo();

    public void destroy();
}
堆栈调用 stack
stack com.wingbow.energy.websocket.WebsocketMonitor sendData
调用耗时 trace
trace com.wingbow.energy.websocket.WebsocketMonitor sendData
参数查看 watch
watch com.wingbow.energy.websocket.WebsocketMonitor sendData {params[0], returnObj, throwExp} -e
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!