原因
一.应用中直接或间接依赖了一个类的多个版本
最常见的就是包冲突(类冲突)
比如直接引用了 common-test-1.0.2-SNAPSHOT.jar ,然后间接引用了 common-test-1.0.1-SNAPSHOT.jar 其中1.0.2 版本 A 类新增了方法 method2(), 运行时用的是1.0.1版本的jar,那么就会报找不到 这个 A 类的 method2() 方法。
同一个jar多版本,运行时使用的哪一个和类加载有关,一般是按照最短路径名去匹配。
二.不存在类冲突,但是方法签名发生了变化
比如方法的入参(参数个数,参数类型等),返回值发生变化
比如应用中原来用的是 method1(param1,param2) 这个方法,然后进行jar替换的时候,method1() 方法变为了无参,那么在运行中就会报这个错。 因为期待是调用方法有两个入参的方法method1(),但实际只有无参的 method1()。
Exception in thread "main" java.lang.NoSuchMethodError: com.xxx.AsyncAppender.method1(Ljava/lang/String;Ljava/lang/String)Ljava/lang/String;
at com.xxx.ProvokeNoSuchMethodError.main(ProvokeNoSuchMethodError:7)
at ……
第二种情况一般出现在fatjar里面。
解决方法
一般报这个错会有具体的日志,说明是调用哪个类的哪个方法,所以可以分以下步骤排查问题
- 先确认这个类的这个方法是否存在,如不存在可能是包冲突,运行时用的是旧版本
- 如果方法存在,进一步确认方法的签名是否正确, 比如方法的入参是否发生变化
先确认一下这个类的这个方法是否存在
如果是在本地启动时报这个错,可以直接看一下引用的是哪个类的哪个方法,就可以知道运行中使用的类对不对。
比如打依赖树看看有没有包冲突, mvn dependency:tree > tree.text
参考文档 添加链接描述