Arthas classloader (查看 classloader 的继承树,urls,类加载信息)

在这里插入图片描述

二、命令列表

2.2 class/classloader相关命令

2.2.4 classloader (查看 classloader 的继承树,urls,类加载信息)

提示

查看 classloader 的继承树,urls,类加载信息。可以让指定的 classloader 去 getResources,打印出所有查找到的 resources 的 url。对于ResourceNotFoundException比较有用。

参数说明:

参数名称参数说明
[l]按类加载实例进行统计
[t]打印所有 ClassLoader 的继承树
[a]列出所有 ClassLoader 加载的类,请谨慎使用
[c:]ClassLoader 的 hashcode
[classLoaderClass:]指定执行表达式的 ClassLoader 的 class name
[c: r:]用 ClassLoader 去查找 resource
[c: load:]用 ClassLoader 去加载指定的类
举例1:按类加载类型查看统计信息

基础语法

classloader

[arthas@26938]$ classloader
 name                                                                numberOfInstances  loadedCountTotal                                                                                                                                
 sun.misc.Launcher$AppClassLoader                                    1                  11669                                                                                                                                           
 BootstrapClassLoader                                                1                  4751                                                                                                                                            
 com.taobao.arthas.agent.ArthasClassloader                           1                  1353                                                                                                                                            
 sun.reflect.DelegatingClassLoader                                   948                948                                                                                                                                             
 com.alibaba.fastjson.util.ASMClassLoader                            2                  170                                                                                                                                             
 sun.misc.Launcher$ExtClassLoader                                    1                  61                                                                                                                                              
 oracle.jrockit.jfr.events.EventHandlerCreator$EventInfoClassLoader  9                  9                                                                                                                                               
Affect(row-cnt:7) cost in 39 ms.
[arthas@26938]$ 
举例2:按类加载实例查看统计信息

基础语法

classloader -l

[arthas@26938]$ classloader -l
 name                                                                         loadedCount  hash      parent                                                                                                                             
 BootstrapClassLoader                                                         4752         null      null                                                                                                                               
 com.alibaba.fastjson.util.ASMClassLoader@2af720e3                            159          2af720e3  sun.misc.Launcher$AppClassLoader@18b4aac2                                                                                          
 com.alibaba.fastjson.util.ASMClassLoader@50893336                            11           50893336  sun.misc.Launcher$AppClassLoader@18b4aac2                                                                                          
 com.taobao.arthas.agent.ArthasClassloader@507764d0                           1360         507764d0  sun.misc.Launcher$ExtClassLoader@232204a1                                                                                          
 oracle.jrockit.jfr.events.EventHandlerCreator$EventInfoClassLoader@372f7a8d  1            372f7a8d  null                                                                                                                               
 oracle.jrockit.jfr.events.EventHandlerCreator$EventInfoClassLoader@27716f4   1            27716f4   null                                                                                                                               
 oracle.jrockit.jfr.events.EventHandlerCreator$EventInfoClassLoader@681a9515  1            681a9515  null                                                                                                                               
 oracle.jrockit.jfr.events.EventHandlerCreator$EventInfoClassLoader@5acf9800  1            5acf9800  null                                                                                                                               
 oracle.jrockit.jfr.events.EventHandlerCreator$EventInfoClassLoader@53d8d10a  1            53d8d10a  null                                                                                                                               
 oracle.jrockit.jfr.events.EventHandlerCreator$EventInfoClassLoader@63961c42  1            63961c42  null                                                                                                                               
 oracle.jrockit.jfr.events.EventHandlerCreator$EventInfoClassLoader@1fb3ebeb  1            1fb3ebeb  null                                                                                                                               
 oracle.jrockit.jfr.events.EventHandlerCreator$EventInfoClassLoader@119d7047  1            119d7047  null                                                                                                                               
 oracle.jrockit.jfr.events.EventHandlerCreator$EventInfoClassLoader@f6f4d33   1            f6f4d33   null                                                                                                                               
 sun.misc.Launcher$AppClassLoader@18b4aac2                                    11669        18b4aac2  sun.misc.Launcher$ExtClassLoader@232204a1                                                                                          
 sun.misc.Launcher$ExtClassLoader@232204a1                                    61           232204a1  null                                                                                                                               
Affect(row-cnt:15) cost in 33 ms.
[arthas@26938]$
举例3:查看 ClassLoader 的继承树

基础语法

classloader -t

[arthas@26938]$ classloader -t
+-BootstrapClassLoader                                                                                                                                                                                                                  
+-oracle.jrockit.jfr.events.EventHandlerCreator$EventInfoClassLoader@372f7a8d                                                                                                                                                           
+-oracle.jrockit.jfr.events.EventHandlerCreator$EventInfoClassLoader@27716f4                                                                                                                                                            
+-oracle.jrockit.jfr.events.EventHandlerCreator$EventInfoClassLoader@681a9515                                                                                                                                                           
+-oracle.jrockit.jfr.events.EventHandlerCreator$EventInfoClassLoader@5acf9800                                                                                                                                                           
+-oracle.jrockit.jfr.events.EventHandlerCreator$EventInfoClassLoader@53d8d10a                                                                                                                                                           
+-oracle.jrockit.jfr.events.EventHandlerCreator$EventInfoClassLoader@63961c42                                                                                                                                                           
+-oracle.jrockit.jfr.events.EventHandlerCreator$EventInfoClassLoader@1fb3ebeb                                                                                                                                                           
+-oracle.jrockit.jfr.events.EventHandlerCreator$EventInfoClassLoader@119d7047                                                                                                                                                           
+-oracle.jrockit.jfr.events.EventHandlerCreator$EventInfoClassLoader@f6f4d33                                                                                                                                                            
+-sun.misc.Launcher$ExtClassLoader@232204a1                                                                                                                                                                                             
  +-com.taobao.arthas.agent.ArthasClassloader@507764d0                                                                                                                                                                                  
  +-sun.misc.Launcher$AppClassLoader@18b4aac2                                                                                                                                                                                           
    +-com.alibaba.fastjson.util.ASMClassLoader@2af720e3                                                                                                                                                                                 
    +-com.alibaba.fastjson.util.ASMClassLoader@50893336                                                                                                                                                                                 
Affect(row-cnt:15) cost in 16 ms.
[arthas@26938]$

本人其他相关文章链接

1.Arthas 全攻略:让调试变得简单
2.Arthas dashboard(当前系统的实时数据面板)
3.Arthas thread(查看当前JVM的线程堆栈信息)
4.Arthas jvm(查看当前JVM的信息)
5.Arthas sysprop(查看和修改JVM的系统属性)
6.Arthas sysenv(查看JVM的环境变量)
7.Arthas vmoption(查看和修改 JVM里诊断相关的option)
8.Arthas getstatic(查看类的静态属性 )
9.Arthas heapdump(dump java heap, 类似 jmap 命令的 heap dump 功能)
10.Arthas logger(查看 logger 信息,更新 logger level)
11.Arthas mbean(查看 Mbean 的信息)
12.Arthas memory(查看 JVM 内存信息)
13.Arthas ognl(执行ognl表达式)
14.Arthas perfcounter(查看当前 JVM 的 Perf Counter 信息)
15.Arthas vmtool(从 jvm 里查询对象,执行 forceGc)
16.Arthas jad(字节码文件反编译成源代码 )
17.Arthas mc(Memory Compiler/内存编译器 )
18.Arthas redefine(加载外部的.class文件,redefine到JVM里 )
19.Arthas classloader (查看 classloader 的继承树,urls,类加载信息)
20.Arthas sc(查看JVM已加载的类信息 )
21.Arthas sm(查看已加载类的方法信息 )
22.Arthas monitor(方法执行监控)
23.Arthas stack (输出当前方法被调用的调用路径)
24.Arthas trace (方法内部调用路径,并输出方法路径上的每个节点上耗时)
25.Arthas tt(方法执行数据的时空隧道,记录下指定方法每次调用的入参和返回信息,并能对这些不同的时间下调用进行观测)
26.Arthas watch (方法执行数据观测)
27.Arthas profiler(使用async-profiler对应用采样,生成火焰图)

为什么要学JVM1、一切JAVA代码都运行在JVM之上,只有深入理解虚拟机才能写出更强大的代码,解决更深层次的问题。2、JVM是迈向高级工程师、架构师的必备技能,也是高薪、高职位的不二选择。3、同时,JVM又是各大软件公司笔试、面试的重中之重,据统计,头部的30家互利网公司,均将JVM作为笔试面试的内容之一。4、JVM内容庞大、并且复杂难学,通过视频学习是最快速的学习手段。课程介绍本课程包含11个大章节,总计102课时,无论是笔试、面试,还是日常工作,可以让您游刃有余。第1章 基础入门,从JVM是什么开始讲起,理解JDK、JRE、JVM的关系,java的编译流程和执行流程,让您轻松入门。第2章 字节码文件,深入剖析字节码文件的全部组成结构,以及javap和jbe可视化反解析工具的使用。第3章 类的加载、解释、编译,本章节带你深入理解类加载器的分类、范围、双亲委托策略,自己手写类加载器,理解字节码解释器、即时编译器、混合模式、热点代码检测、分层编译等核心知识。第4章 内存模型,本章节涵盖JVM内存模型的全部内容,程序计数器、虚拟机栈、本地方法栈、方法区、永久代、元空间等全部内容。第5章 对象模型,本章节带你深入理解对象的创建过程、内存分配的方法、让你不再稀里糊涂。第6章 GC基础,本章节是垃圾回收的入门章节,带你了解GC回收的标准是什么,什么是可达性分析、安全点、安全区,四种引用类型的使用和区别等等。第7章 GC算法与收集器,本章节是垃圾回收的重点,掌握各种垃圾回收算法,分代收集策略,7种垃圾回收器的原理和使用,垃圾回收器的组合及分代收集等。第8章 GC日志详解,各种垃圾回收器的日志都是不同的,怎么样读懂各种垃圾回收日志就是本章节的内容。第9章 性能监控与故障排除,本章节实战学习jcmd、jmx、jconsul、jvisualvm、JMC、jps、jstatd、jmap、jstack、jinfo、jprofile、jhat总计12种性能监控和故障排查工具的使用。第10章 阿里巴巴Arthas在线诊断工具,这是一个特别小惊喜,教您怎样使用当前最火热的arthas调优工具,在线诊断各种JVM问题。第11章 故障排除,本章会使用实际案例讲解单点故障、高并发和垃圾回收导致的CPU过高的问题,怎样排查和解决它们。课程资料课程附带配套项目源码2个159页高清PDF理论篇课件1份89页高清PDF实战篇课件1份Unsafe源码PDF课件1份class_stats字段说明PDF文件1份jcmd Thread.print解析说明文件1份JProfiler内存工具说明文件1份字节码可视化解析工具1份GC日志可视化工具1份命令行工具cmder 1份学习方法理论篇部分推荐每天学习2课时,可以在公交地铁上用手机进行学习。实战篇部分推荐对照视频,使用配套源码,一边练习一遍学习。课程内容较多,不要一次性学太多,而是要循序渐进,坚持学习。      
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

刘大猫.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值