编程语言
首页 > 编程语言> > 独孤九剑之Elasticsearch Java API破剑式

独孤九剑之Elasticsearch Java API破剑式

作者:互联网

0、题记
之前Elasticsearch的应用比较多,但大多集中在关系型、非关系型数据库与Elasticsearch之间的同步。以上内容完成了Elasticsearch所需要的基础数据量的供给。但想要在海量的数据中找到和自己相关的业务数据,实现对已有的数据实现全文检索、分类统计等功能并应用到业务系统中,必须借助Java API来实现。

1、Elasticsearch Java API 概览
Elasticsearch Java API 相关使用研究结果:

1.1 国内的博文讲解Elasticsearch Java API 大多偏重于实现,没有对Elasticsearch Java API 整体进行讲解。这样的问题是头疼医头,脚痛医脚,始终不得原理。

1.2 Elasticsearch1.X,2.X,5.X随着版本的迭代,除了系统升级,Java API也做了相对较大的调整。

也就是说,1.X的API在2.X以及5.X乃至未来6.X版本都不是通用的。如1.x的fuzzyLikeThisQuery在后续版本都不再存在。

1.3 Elasticsearch官网Java API提供了相对丰富的解读。(文末参考给出了官网地址)

1.4 Elasticsearch Java API 大致分如下四类:

1.4.1、TransportClient

步骤1:获取client;

步骤2:执行对应的增、删、改、查操作。

查询使用参考(以下我已经验证过,好用ok):

/**

elasticsearch 5.0引入了一个新的客户端 RestClient ,使用HTTP API elasticsearch代替内部协议。这需要更少依赖关系。你也不需要关注那么多版本,当前客户端也可以用于elasticsearch 2.x版本。

使用参考如下(以下我没有代码验证):

HttpEntity entity = new NStringEntity(
"{ \"query\": { \"match_all\": {}}}",
ContentType.APPLICATION_JSON);
// alternative: performRequestAsync
Response response = restClient.performRequest("POST", "/_search", emptyMap(), entity);
String json = toString(response.getEntity());
// ...
1.4.3、Jest

Jest是ElasticSearch的Java HTTP Rest客户端。 Jest填补了 ElasticSearch 缺少 Http Rest接口 客户端的空白。

通过Maven编译实现,需要设定好不同的版本。现在pom.xml最新的Elasticsearch版本为5.3.3(2017年5月27日),5.3.3的API向ES2.3.4插入索引数据,不能保障数据正常插入,且没有报错。

具体使用参考(以下示例跑通,验证ok):

/**

Search search = new Search.Builder(searchSourceBuilder.toString())
// .addIndex("article")
.build();
SearchResult result = jestClient.execute(search);
System.out.println(result.getJsonString());
}
1.4.3.1 Jest介绍

Jest是Elasticsearch 的Java Http Rest 客户端。

ElasticSearch已经具备应用于Elasticsearch内部的Java API,但是Jest弥补了ES自有API缺少Elasticsearch Http Rest接口客户端的不足。

1.4.3.2、 Jest优势概括如下:

1)提供Restful API, 原生ES API不具备;

2)若ES集群使用不同的ES版本,使用原生ES API会有问题,而Jest不会;

3) 更安全(可以在Http层添加安全处理)。

1.4.3.3、pom

概括下,Jest使用maven的方式管理项目。支持最新的Elasticsearch。

pom.xml有相关配置信息。(默认是最新ES版本相关的pom.xml,截止:2017-08-13 16:38, 其默认支持版本5.3.2)。

<dependency>

<groupId>io.searchbox</groupId>
<artifactId>jest</artifactId>
<version>2.0.0</version>
</dependency>
高版本ES也是可以使用的,我实际开发ES5.4.0,用的JEST的做的后端接口开发。

1.4.3.4、Jest使用

喜欢的点点关注,点点赞。
对Java技术,架构技术感兴趣的同学,欢迎加QQ群668041364?,一起学习,相互讨论。

群内已经有小伙伴将知识体系整理好(源码,笔记,PPT,学习视频),欢迎加群领取。

标签:1.4,独孤九剑,Java,API,Elasticsearch,Jest,ES
来源: https://blog.51cto.com/14233733/2403647