问题:
Spring boot2.x + Elasticsearch7.x 项目启动失败,抛出异常
java.lang.NoSuchFieldError: LATEST
at org.elasticsearch.Version.<clinit>(Version.java:49)
at org.elasticsearch.common.io.stream.StreamInput.<init>(StreamInput.java:111)
at org.elasticsearch.common.bytes.BytesReference$MarkSupportingStreamInputWrapper.<init>(BytesReference.java:309)
at org.elasticsearch.common.bytes.BytesReference$MarkSupportingStreamInputWrapper.<init>(BytesReference.java:303)
at org.elasticsearch.common.bytes.BytesReference.streamInput(BytesReference.java:105)
at org.elasticsearch.common.xcontent.XContentHelper.createParser(XContentHelper.java:78)
at org.elasticsearch.client.RequestConverters.bulk(RequestConverters.java:230)
根据提示,可以看出,是 jar 包版本冲突的问题
解决过程
1、借助IDEA,安装一个 Maven Helper 插件
2、安装完插件之后,重启IDEA,打开 pom.xml 文件,可以发现,多了一个选项卡 Dependency Analyzer
3、点击 Conflicts ,可以查看当前冲突的 jar
我们知道,Elasticsearch,是依赖 lucene。先排除一下 lucene 是否有冲突
从上图,可以看出,当前项目存在两个不同版本的 lucene。
在图片右边,相应的版本上面,右键
点击 ① Jump To Source [F4] —— 可以跳转到 pom 文件,并定位到引入 jar 节点
点击 ② exclude,idea会帮我们自动在pom文件中进行配置忽略,从而快速解决jar冲突
我这边出现问题的情况是,ikanalyzer 分词的问题
<dependency>
<groupId>com.janeluo</groupId>
<artifactId>ikanalyzer</artifactId>
<version>2012_u6</version>
</dependency>
由于 ikanalyzer 分词,也依赖 lucene,但是他的版本比较老,才4.7.2。
我这边项目的实际情况是:原先使用 ik 分词,进行数据的匹配。但是目前已不满足业务需求,故使用 ES代替。
ik 分词对我来说,已经没有意义了,所以我直接删除。