【Arthas案例】某应用依赖两个GAV-classifier不同的snakeyaml.jar,引起NoSuchMethodError

3分钟内解决问题

两个不同的GAV-classifier依赖冲突,引起NoSuchMethodError

Maven依赖的三坐标体系GAV(G-groupId,A-artifactId,V-version)

classifier通常用于区分从同一POM构建的具有不同内容的构件物(artifact)。它是可选的,它可以是任意的字符串,附加在版本号之后。

【案例1】某应用依赖两个GAV-classifier不同的snakeyaml.jar,引起NoSuchMethodError

1.完整的异常调用栈【从案发现场找线索】

警察抓犯人,收集线索是破案的关键所在。

2.关键的异常日志

从异常信息中收集有用的线索。

shell 复制代码
java.lang.NoSuchMethodError: org.yaml.snakeyaml.constructor.SafeConstructor.<init>(Lorg/yaml/snakeyaml/LoaderOptions;)V
  at org.apache.dubbo.rpc.cluster.router.condition.config.model.ConditionRuleParser.parse(ConditionRuleParser.java:44)

java.lang.NoSuchMethodError that class no longer has a definition of that method.

该类不再具有该方法的定义。

3.案发现场的源代码

org.apache.dubbo.rpc.cluster.router.condition.config.model.ConditionRuleParser.parse(ConditionRuleParser.java:44)

  • jad - 反编译指定已加载类的源码
shell 复制代码
[arthas@41915]$ jad org.apache.dubbo.rpc.cluster.router.condition.config.model.ConditionRuleParser parse

ConditionRuleParser.java:44,与异常信息对上了。

org.yaml.snakeyaml.constructor.SafeConstructor点击链接到snakeyaml-1.23-android.jar

4.应用里依赖两个snakeyaml.jar是怎么回事?

Maven: org.yaml:snakeyaml:1.26,依赖管理声明自spring-boot-dependencies

Maven: org.yaml:snakeyaml:android:1.23,从其他依赖透明传递下来

5.使用Arthas命令确认已加载的类信息和方法信息

class/classloader 相关

破案杀手锏

  • sc - 查看 JVM 已加载的类信息
  • sm - 查看已加载类的方法信息
shell 复制代码
[arthas@41915]$ sc -d org.yaml.snakeyaml.constructor.SafeConstructor
 class-info        org.yaml.snakeyaml.constructor.SafeConstructor
 code-source       /Users/lihuagang/.m2/repository/org/yaml/snakeyaml/1.23/snakeyaml-1.23-android.jar
 name              org.yaml.snakeyaml.constructor.SafeConstructor
 isInterface       false
 isAnnotation      false
 isEnum            false
 isAnonymousClass  false
 isArray           false
 isLocalClass      false
 isMemberClass     false
 isPrimitive       false
 isSynthetic       false
 simple-name       SafeConstructor
 modifier          public
 annotation
 interfaces
 super-class       +-org.yaml.snakeyaml.constructor.BaseConstructor
                     +-java.lang.Object
 class-loader      +-sun.misc.Launcher$AppClassLoader@18b4aac2
                     +-sun.misc.Launcher$ExtClassLoader@4d95d2a2
 classLoaderHash   18b4aac2

Affect(row-cnt:2) cost in 34 ms.


[arthas@41915]$ sm org.yaml.snakeyaml.constructor.SafeConstructor <init>
org.yaml.snakeyaml.constructor.SafeConstructor <init>()V

Affect(row-cnt:2) cost in 55 ms.

[arthas@41915]$ sm -d org.yaml.snakeyaml.constructor.SafeConstructor <init>
 declaring-class   org.yaml.snakeyaml.constructor.SafeConstructor
 constructor-name  <init>
 modifier          public
 annotation
 parameters
 exceptions
 classLoaderHash   18b4aac2
  • 通过sc -d org.yaml.snakeyaml.constructor.SafeConstructor,可以看到其加载自snakeyaml-1.23-android.jar
  • 通过sm org.yaml.snakeyaml.constructor.SafeConstructor <init>,可以看到没有org.yaml.snakeyaml.constructor.SafeConstructor#SafeConstructor(org.yaml.snakeyaml.LoaderOptions)构造函数的方法签名。
  • 综上所述,与异常信息完全符合。

6.解决方法

snakeyaml-1.23-android.jar依赖排除掉,搞定。


祝大家玩得开心!ˇˍˇ

广益,杭州

相关推荐
invicinble2 分钟前
对tomcat的提供的功能与底层拓扑结构与实现机制的理解
java·tomcat
较真的菜鸟15 分钟前
使用ASM和agent监控属性变化
java
黎雁·泠崖22 分钟前
【魔法森林冒险】5/14 Allen类(三):任务进度与状态管理
java·开发语言
2的n次方_1 小时前
CANN ascend-transformer-boost 架构解析:融合注意力算子管线、长序列分块策略与图引擎协同机制
深度学习·架构·transformer
qq_12498707532 小时前
基于SSM的动物保护系统的设计与实现(源码+论文+部署+安装)
java·数据库·spring boot·毕业设计·ssm·计算机毕业设计
Coder_Boy_2 小时前
基于SpringAI的在线考试系统-考试系统开发流程案例
java·数据库·人工智能·spring boot·后端
Mr_sun.2 小时前
Day06——权限认证-项目集成
java
瑶山2 小时前
Spring Cloud微服务搭建四、集成RocketMQ消息队列
java·spring cloud·微服务·rocketmq·dashboard
abluckyboy2 小时前
Java 实现求 n 的 n^n 次方的最后一位数字
java·python·算法
2301_818732062 小时前
前端调用控制层接口,进不去,报错415,类型不匹配
java·spring boot·spring·tomcat·intellij-idea