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课时,可以在公交地铁上用手机进行学习。实战篇部分推荐对照视频,使用配套源码,一边练习一遍学习。课程内容较多,不要一次性学太多,而是要循序渐进,坚持学习。      
<think>好的,我现在需要处理用户的问题:“显示类有问题,内存加载有问题”。首先,我需要理解用户的具体需求。用户之前询问过关于JAR包被植入木马的问题,现在转向了类加载和内存的问题。可能用户在使用Java应用时遇到了类加载失败或内存相关的错误,比如ClassNotFoundException、NoClassDefFoundError,或者内存泄漏导致的应用崩溃。 接下来,我要考虑用户可能的背景。用户可能是一名Java开发者,或者正在维护一个Java应用,遇到了技术问题需要排查。用户可能对Java的类加载机制和内存管理有一定的了解,但不够深入,需要详细的解释和解决方案。 用户的问题比较模糊,“显示类有问题”可能指的是类加载时出现的错误信息,而“内存加载有问题”可能涉及内存分配、泄漏或垃圾回收问题。我需要将这两个方面分开解释,同时也要指出它们之间可能的联系。 首先,类加载问题。Java的类加载机制涉及多个阶段:加载、验证、准备、解析、初始化。常见的错误包括类路径配置错误、类版本不兼容、依赖缺失等。例如,ClassNotFoundException通常是因为类加载器找不到指定的类文件,而NoClassDefFoundError可能在编译时有类,但运行时缺少依赖。需要检查类路径、依赖管理工具(如Maven、Gradle)的配置,以及JAR包是否完整。 然后,内存加载问题。这可能指内存溢出(OutOfMemoryError),通常由内存泄漏或不当的内存使用引起。需要分析堆内存、栈内存、方法区的使用情况。工具如jstat、jmap、VisualVM、Eclipse MAT可以帮助诊断。另外,需要考虑垃圾回收器的配置和日志分析,是否存在频繁的Full GC,或者对象无法被回收的情况。 用户可能还需要了解如何排查这些问题。例如,如何生成和分析堆转储文件,如何查看类加载信息,如何监控内存使用情况。需要提供具体的命令和步骤,比如使用jcmd、jstack,或者配置JVM参数开启调试日志。 同时,考虑到用户之前的问题涉及安全方面,可能需要提醒用户在排查类加载问题时,注意是否有恶意类被加载,尤其是在动态类加载或使用反射的情况下。安全管理和类加载器的隔离也是需要考虑的因素。 此外,用户的问题可能涉及底层机制,需要解释类加载器的层次结构(引导类加载器、扩展类加载器、系统类加载器、自定义类加载器),以及双亲委派模型的工作原理。内存方面则需要解释堆、栈、方法区、直接内存的区别,以及垃圾回收的基本原理。 最后,要确保回答结构清晰,分点说明,提供实际的命令和代码示例,帮助用户逐步排查问题。同时,语言要简洁明了,避免过于专业的术语,必要时给出示例,比如如何设置JVM参数,如何使用工具分析内存快照。</think>以下是关于Java程序中类加载与内存管理问题的技术解析: 一、类加载问题排查 1. 常见错误类型 - ClassNotFoundException:类加载器在指定路径找不到类文件 - NoClassDefFoundError:编译时存在但运行时缺失依赖类 - UnsupportedClassVersionError:JDK版本不兼容(如用JDK11编译,用JRE8运行) 2. 诊断步骤 (1) 检查类路径配置 ```bash # 显示实际加载的类路径 java -verbose:class -jar app.jar | grep "Loaded" ``` (2) 验证依赖完整性 ```bash # Maven项目检查依赖树 mvn dependency:tree > deps.txt # 查找重复类 mvn enforcer:enforce -Drules=banDuplicateClasses ``` (3) 类加载器分析 ```java public static void printClassLoader(Class<?> clazz) { System.out.println("Class loader chain:"); ClassLoader loader = clazz.getClassLoader(); while (loader != null) { System.out.println("→ " + loader.toString()); loader = loader.getParent(); } } ``` 二、内存加载问题排查 1. 内存错误类型 - OutOfMemoryError: Java heap space(堆内存不足) - OutOfMemoryError: Metaspace(元空间溢出) - OutOfMemoryError: Unable to create new native thread(线程数超限) 2. 诊断工具链 (1) 实时监控 ```bash # 监控堆内存使用 jstat -gcutil <pid> 1000 # 显示内存映射 jcmd <pid> VM.native_memory ``` (2) 堆转储分析 ```bash # 生成堆转储文件 jmap -dump:live,format=b,file=heap.hprof <pid> ``` 使用Eclipse MAT分析对象保留链 3. 典型内存泄漏场景 - 静态集合长期持有对象引用 - 未关闭的资源(数据库连接、文件流) - 监听器未正确注销 - 不合理的缓存策略 三、综合调试技巧 1. JVM参数配置示例 ```bash java -Xmx1024m -Xms512m \ -XX:+HeapDumpOnOutOfMemoryError \ -XX:HeapDumpPath=./oom_dump.hprof \ -XX:+PrintGCDetails \ -verbose:class \ -jar application.jar ``` 2. 线程堆栈分析 ```bash # 生成线程快照 jstack -l <pid> > thread_dump.log # 检测死锁 grep -A 10 "deadlock" thread_dump.log ``` 3. 类加载监控 ```java // 添加调试参数 -XX:+TraceClassLoading -XX:+TraceClassUnloading ``` 四、进阶解决方案 1. 类加载问题优化 - 使用模块化系统(JPMS)明确依赖 - 实现自定义类加载器的隔离机制 ```java public class IsolatedClassLoader extends URLClassLoader { public IsolatedClassLoader(URL[] urls) { super(urls, null); // 切断父委托 } } ``` 2. 内存管理策略 - 使用软引用/弱引用优化缓存 ```java Map<Key, SoftReference<Value>> cache = new WeakHashMap<>(); ``` - 启用G1垃圾回收器 ```bash -XX:+UseG1GC -XX:MaxGCPauseMillis=200 ``` 建议结合Arthas等在线诊断工具进行实时分析: ```bash # 查看类加载信息 sc -d com.example.MyClass # 监控方法调用 watch com.example.Service * '{params, returnObj}' -x 3 ``` 遇到具体错误时,可按照以下步骤排查: 1. 检查错误日志中的类名/内存区域 2. 使用jcmd或jinfo获取JVM运行参数 3. 通过VisualVM进行实时监控 4. 对比正常情况与异常时的内存/类加载状态 5. 进行压力测试复现问题
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

刘大猫.

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

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

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

打赏作者

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

抵扣说明:

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

余额充值