github地址:

Arthas

English version goes here.

Arthas 是Alibaba开源的Java诊断工具,深受开发者喜爱。

当你遇到以下类似问题而束手无策时,Arthas可以帮助你解决:

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

Arthas采用命令行交互模式,同时提供丰富的 Tab 自动补全功能,进一步方便进行问题的定位和诊断。

快速开始

Linux/Unix/Mac

安装Arthas:

curl -L https://alibaba.github.io/arthas/install.sh | sh

启动Arthas:

./as.sh

Windows

  1. 点击 这里 下载最新的Arthas zip包
  2. 解压缩zip包.
  3. 进入bin目录
  4. 执行以下命令 as.bat $PID

文档

社区正在进行英文版本的翻译工作,如果您有兴趣请在 这里留言。

案例展示

Dashboard

Thread

一目了然的了解系统的状态,哪些线程比较占cpu?他们到底在做什么?

  1.  
    $ thread -n 3
  2.  
    "as-command-execute-daemon" Id=29 cpuUsage=75% RUNNABLE
  3.  
    at sun.management.ThreadImpl.dumpThreads0(Native Method)
  4.  
    at sun.management.ThreadImpl.getThreadInfo(ThreadImpl.java:440)
  5.  
    at com.taobao.arthas.core.command.monitor200.ThreadCommand$1.action(ThreadCommand.java:58)
  6.  
    at com.taobao.arthas.core.command.handler.AbstractCommandHandler.execute(AbstractCommandHandler.java:238)
  7.  
    at com.taobao.arthas.core.command.handler.DefaultCommandHandler.handleCommand(DefaultCommandHandler.java:67)
  8.  
    at com.taobao.arthas.core.server.ArthasServer$4.run(ArthasServer.java:276)
  9.  
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
  10.  
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
  11.  
    at java.lang.Thread.run(Thread.java:745)
  12.  
     
  13.  
    Number of locked synchronizers = 1
  14.  
    - java.util.concurrent.ThreadPoolExecutor$Worker@6cd0b6f8
  15.  
     
  16.  
    "as-session-expire-daemon" Id=25 cpuUsage=24% TIMED_WAITING
  17.  
    at java.lang.Thread.sleep(Native Method)
  18.  
    at com.taobao.arthas.core.server.DefaultSessionManager$2.run(DefaultSessionManager.java:85)
  19.  
     
  20.  
    "Reference Handler" Id=2 cpuUsage=0% WAITING on java.lang.ref.Reference$Lock@69ba0f27
  21.  
    at java.lang.Object.wait(Native Method)
  22.  
    - waiting on java.lang.ref.Reference$Lock@69ba0f27
  23.  
    at java.lang.Object.wait(Object.java:503)
  24.  
    at java.lang.ref.Reference$ReferenceHandler.run(Reference.java:133)

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();
}

sc

查找JVM中已经加载的类

  1.  
    $ sc -d org.springframework.web.context.support.XmlWebApplicationContext
  2.  
    class-info org.springframework.web.context.support.XmlWebApplicationContext
  3.  
    code-source /Users/xxx/work/test/WEB-INF/lib/spring-web-3.2.11.RELEASE.jar
  4.  
    name org.springframework.web.context.support.XmlWebApplicationContext
  5.  
    isInterface false
  6.  
    isAnnotation false
  7.  
    isEnum false
  8.  
    isAnonymousClass false
  9.  
    isArray false
  10.  
    isLocalClass false
  11.  
    isMemberClass false
  12.  
    isPrimitive false
  13.  
    isSynthetic false
  14.  
    simple-name XmlWebApplicationContext
  15.  
    modifier public
  16.  
    annotation
  17.  
    interfaces
  18.  
    super-class +-org.springframework.web.context.support.AbstractRefreshableWebApplicationContext
  19.  
    +-org.springframework.context.support.AbstractRefreshableConfigApplicationContext
  20.  
    +-org.springframework.context.support.AbstractRefreshableApplicationContext
  21.  
    +-org.springframework.context.support.AbstractApplicationContext
  22.  
    +-org.springframework.core.io.DefaultResourceLoader
  23.  
    +-java.lang.Object
  24.  
    class-loader +-org.apache.catalina.loader.ParallelWebappClassLoader
  25.  
    +-java.net.URLClassLoader@6108b2d7
  26.  
    +-sun.misc.Launcher$AppClassLoader@18b4aac2
  27.  
    +-sun.misc.Launcher$ExtClassLoader@1ddf84b8
  28.  
    classLoaderHash 25131501
  29.  
     

stack

查看方法 test.arthas.TestStack#doGet 的调用堆栈:

  1.  
    $ stack test.arthas.TestStack doGet
  2.  
    Press Ctrl+C to abort.
  3.  
    Affect(class-cnt:1 , method-cnt:1) cost in 286 ms.
  4.  
    ts=2018-09-18 10:11:45;thread_name=http-bio-8080-exec-10;id=d9;is_daemon=true;priority=5;TCCL=org.apache.catalina.loader.ParallelWebappClassLoader@25131501
  5.  
    @test.arthas.TestStack.doGet()
  6.  
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:624)
  7.  
    at javax.servlet.http.HttpServlet.service(HttpServlet.java:731)
  8.  
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:303)
  9.  
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
  10.  
    at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:52)
  11.  
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
  12.  
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
  13.  
    at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:241)
  14.  
    at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:208)
  15.  
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:220)
  16.  
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:110)
  17.  
    ...
  18.  
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:169)
  19.  
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:103)
  20.  
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:116)
  21.  
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:451)
  22.  
    at org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1121)
  23.  
    at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:637)
  24.  
    at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:316)
  25.  
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
  26.  
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
  27.  
    at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)
  28.  
    at java.lang.Thread.run(Thread.java:745)

Trace

观察方法执行的时候那个子调用比较慢:

Watch

观察方法 test.arthas.TestWatch#doGet 执行的入参,仅当方法抛出异常时才输出。

  1.  
    $ watch test.arthas.TestWatch doGet {params[0], throwExp} -e
  2.  
    Press Ctrl+C to abort.
  3.  
    Affect(class-cnt:1 , method-cnt:1) cost in 65 ms.
  4.  
    ts=2018-09-18 10:26:28;result=@ArrayList[
  5.  
    @RequestFacade[org.apache.catalina.connector.RequestFacade@79f922b2],
  6.  
    @NullPointerException[java.lang.NullPointerException],
  7.  
    ]

Classloader

了解当前系统中有多少类加载器,以及每个加载器加载的类数量,帮助您判断是否有类加载器泄露。

  1.  
    $ classloader
  2.  
    name numberOfInstances loadedCountTotal
  3.  
    BootstrapClassLoader 1 3346
  4.  
    com.taobao.arthas.agent.ArthasClassloader 1 1262
  5.  
    java.net.URLClassLoader 2 1033
  6.  
    org.apache.catalina.loader.ParallelWebappClassLoader 1 628
  7.  
    sun.reflect.DelegatingClassLoader 166 166
  8.  
    sun.misc.Launcher$AppClassLoader 1 31
  9.  
    com.alibaba.fastjson.util.ASMClassLoader 6 15
  10.  
    sun.misc.Launcher$ExtClassLoader 1 7
  11.  
    org.jvnet.hk2.internal.DelegatingClassLoader 2 2
  12.  
    sun.reflect.misc.MethodUtil 1 1

Web Console

阿里重磅开源在线分析诊断工具Arthas(阿尔萨斯)的更多相关文章

  1. 开源在线分析诊断工具Arthas(阿尔萨斯)--总结

    阿里重磅开源在线分析诊断工具Arthas(阿尔萨斯) arthas用法 启动demo java -jar arthas-demo.jar 启动 java -jar arthas-boot.jar at ...

  2. 【Java】15分钟快速体验阿里Java诊断工具Arthas

    [墙裂推荐]15分钟快速体验阿里Java诊断工具Arthas : https://alibaba.github.io/arthas/arthas-tutorials?language=cn&i ...

  3. java 诊断工具——Arthas

    该说不说!小编做的这些功能,最讨厌的就是优化!某些前辈大佬写的代码小辈我实在不敢恭维!那逻辑!那sql! 接下来!今天的主角就登场了,阿里巴巴最近开源出来的一个针对 java 的工具,主要是针对 ja ...

  4. Java诊断工具Arthas

    Java诊断工具Arthas 1. Arthas简介 Arthas是阿里开源的一个线上java诊断工具,发现阿里还是挺喜欢开源一些技术的,造福人类.昨天试用了一下,发现真是强大,解决了我工作两年的很多 ...

  5. Alibaba Java诊断工具Arthas之快速安装和简单使用

    Alibaba Java诊断工具Arthas简单介绍 : 当你遇到以下类似问题而束手无策时,Arthas可以帮助你解决: 1.这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception ...

  6. 款阿里开源的 Java 诊断工具Arthas

    Arthas是什么鬼? Arthas是一款阿里巴巴开源的 Java 线上诊断工具,功能非常强大,可以解决很多线上不方便解决的问题. Arthas诊断使用的是命令行交互模式,支持JDK6+,Linux. ...

  7. Arthas Alibaba 开源 Java 诊断工具

    Arthas 用户文档 English Docs Arthas(阿尔萨斯) 能为你做什么? Arthas 是Alibaba开源的Java诊断工具,深受开发者喜爱. 当你遇到以下类似问题而束手无策时,A ...

  8. 阿里JAVA诊断工具Arthas的初步使用

    Arthas 是Alibaba开源的Java诊断工具,主要解决以下问题: 这个类从哪个 jar 包加载的?为什么会报各种类相关的 Exception? 我改的代码为什么没有执行到?难道是我没 comm ...

  9. Arthas--Java在线分析诊断工具(阿尔萨斯)

    序言 Arthas是一款阿里巴巴开源的 Java 线上诊断工具,功能非常强大,可以解决很多线上不方便解决的问题. 资料 https://blog.csdn.net/youanyyou/article/ ...

随机推荐

  1. python 私有和保护成员变量如何实现?—— "单下划线 " 开始的成员变量叫做保护变量,意思是只有类实例和子类实例能访问到这些变量;" 双下划线 " 开始的是私有成员,意思是只有类对象自己能访问,连子类对象也不能访问到这个数据

    默认情况下,Python中的成员函数和成员变量都是公开的(public),在python中没有类似public,private等关键词来修饰成员函数和成员变量.在python中定义私有变量只需要在变量 ...

  2. linux文档与目录结构

    Linux文件系统结构 本文转自 https://www.cnblogs.com/pyyu/p/9213237.html Linux目录结构的组织形式和Windows有很大的不同.首先Linux没有“ ...

  3. nginx+keepalived高可用 (主从+双主)

    1.Nginx+keepalived 主从配置这种方案,使用一个vip地址,前端使用2台机器,一台做主,一台做备,但同时只有一台机器工作,另一台备份机器在主机器不出现故障的时候,永远处于浪费状态,对于 ...

  4.  Django REST framework解析器和渲染器

    解析器 解析器的作用 解析器的作用就是服务端接收客户端传过来的数据,把数据解析成自己可以处理的数据.本质就是对请求体中的数据进行解析. 在了解解析器之前,我们要先知道Accept以及ContentTy ...

  5. LightOJ - 1102 - Problem Makes Problem(组合数)

    链接: https://vjudge.net/problem/LightOJ-1102 题意: As I am fond of making easier problems, I discovered ...

  6. P4357 [CQOI2016]K远点对

    题意:给定平面中的 \(n\) 个点,求第 \(K\) 远的点对之间的距离,\(n\leq 1e5,K\leq min(100,\frac{n\times (n-1)}{2})\) 题解:kd-tre ...

  7. bzoj 3566: [SHOI2014]概率充电器 数学期望+换根dp

    题意:给定一颗树,树上每个点通电概率为 $q[i]$%,每条边通电的概率为 $p[i]$%,求期望充入电的点的个数. 期望在任何时候都具有线性性,所以可以分别求每个点通电的概率(这种情况下期望=概率 ...

  8. C# 中文序列按笔画排序

    问题:给定一串含中文的序列,按首字符的笔画数排序 因为默认是按拼音来排序的, 借助Globalization命名空间,包含定义区域性相关信息的类,这些信息包括语言,国家/地区,正在使用的日历,日期.货 ...

  9. AspNetCore3.0 和 JWT

    添加NuGet引用 IdentityModel Microsoft.AspNetCore.Authorization.JwtBearer 在appsettings.json中添加JwtBearer配置 ...

  10. ubuntu安装mysql自动输入密码随笔记录

    sudo debconf-set-selections <<< 'mysql-server mysql-server/root_password password your_pass ...