错误信息:

java.lang.NoSuchMethodError: org.apache.flink.streaming.connectors.elasticsearch7.ElasticsearchSink: method <init>()V not found

产生原因:

method ()V not found这种原因就是没找到正确的无参构造方法:

  1. 引用的类里面没有无参构造方法
  2. 引用的类出现冲突,有两个或以上的方法被捕获,但是系统无法判断用哪个

我的问题:

出于某种原因,我需要继承flink-connector-es的ElasticsearchSink这个类,但是这个类的构造方法是private,只提供了一个builder,不允许继承,于是我就把源码扒出来,把private改成了public,并且加了一个无参构造方法,然后顺利的继承了这个类,但是没有注意的是,我项目的路径名和ElasticsearchSink源码包路径名完全一样,导致打jar包的时候,源码ElasticsearchSink类和我自己改造的ElasticsearchSink类打到同一个目录下了,然后代码在运行的时候就报了上述错误。

总结:

但凡是属于java.lang.NoSuchMethodError这中错误的通常就是两种情况,一是没有找到这个依赖,需要重新引入,二是找到了多个依赖,可能是多版本的情况,也可能是打包打到同一个包去了。排查办法就是先排查依赖,可以用maven的show dependencie,或者idea的Dependency Analyzer插件,排查是否缺少依赖或着是否有依赖冲突,然后确定一个版本就可以了。

Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐