总结一下elasticsearch java api开发过程中遇到的一些问题。
elasticsearch版本:5.1.2
PreBuiltTransportClient找不到
当我们按elasticsearch老版本2.x一样引用maven文件时,如下:
<dependency>
<groupId>org.elasticsearch</groupId>
<artifactId>elasticsearch</artifactId>
<version>5.1.2</version>
</dependency>
在我们创建elasticsearch的TransportClient时候
TransportClient client = new PreBuiltTransportClient(),提示无法找到PreBuiltTransportClient类。
这是由于elasticsearch从5.x开始客户端放在了新的jar包里,我们需要引用如下:
<dependency>
<groupId>org.elasticsearch.client</groupId>
<artifactId>transport</artifactId>
<version>5.1.2</version>
</dependency>
找不到log4j类
执行java查询时候,报错如下:
Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/logging/log4j/Logger
at org.elasticsearch.common.logging.Loggers.getLogger(Loggers.java:105)
at org.elasticsearch.common.logging.Loggers.getLogger(Loggers.java:72)
at org.elasticsearch.common.component.AbstractComponent.<init>(AbstractComponent.java:37)
at org.elasticsearch

本文总结了在使用Elasticsearch 5.1.2版本时,通过Java API开发遇到的问题,包括PreBuiltTransportClient找不到、log4j依赖缺失、index级别settings设置错误以及如何在5.x版本中指定返回字段。解决方案包括更新客户端引用、添加log4j依赖、调整settings配置以及使用setFetchSource方法设置返回字段。
2141

被折叠的 条评论
为什么被折叠?



