【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依赖排除掉,搞定。


祝大家玩得开心!ˇˍˇ

广益,杭州

相关推荐
神の愛15 分钟前
左连接查询数据 left join
java·服务器·前端
南境十里·墨染春水36 分钟前
linux学习进展 线程同步——互斥锁
java·linux·学习
雨奔1 小时前
Kubernetes 联邦 Deployment 指南:跨集群统一管理 Pod
java·容器·kubernetes
杨凯凡1 小时前
【021】反射与注解:Spring 里背后的影子
java·后端·spring
lulu12165440781 小时前
Claude Code项目大了响应慢怎么办?Subagents、Agent Teams、Git Worktree、工作流编排四种方案深度解析
java·人工智能·python·ai编程
riNt PTIP1 小时前
SpringBoot创建动态定时任务的几种方式
java·spring boot·spring
老星*2 小时前
AI选股核心设计思路
java·ai·开源·软件开发
それども2 小时前
Comparator.comparing 和 拆箱问题
java·jvm
星晨羽3 小时前
西门子机床opc ua协议实现变量读写及NC文件上传下载
java·spring boot
无巧不成书02184 小时前
零基础Java网络编程全解:从核心概念到Socket实战,一文打通Java网络通信
java·开发语言·网络