【ES实战】ES6.8到9.1.4的常用客户端变化

ES6.8到9.1.4的常用客户端变化

VIP文章陆续免费更新,需优先的文章,请留言

文章目录

  • ES6.8到9.1.4的常用客户端变化
    • [Elasticsearch for Apache Hadoop and Spark](#Elasticsearch for Apache Hadoop and Spark)
    • [Transport Client](#Transport Client)
    • [High Level Rest Client](#High Level Rest Client)
    • [Low Level Rest Client](#Low Level Rest Client)
    • [Java API Client](#Java API Client)
    • [Elasticsearch 官网中一些更新的说明](#Elasticsearch 官网中一些更新的说明)
    • [附录 Java API Client重大变更策略](#附录 Java API Client重大变更策略)

主要涉及的客户端

  1. Elasticsearch for Apache Hadoop and Spark
  2. Transport Client
  3. High Level Rest Client
  4. Low Level Rest Client
  5. Java API Client

客户端们涉及的maven仓库地址

Elasticsearch for Apache Hadoop and Spark

介绍网址https://www.elastic.co/guide/en/elasticsearch/hadoop/index.html

依赖

xml 复制代码
<dependency>
    <groupId>org.elasticsearch</groupId>
    <artifactId>elasticsearch-hadoop</artifactId>
    <version>9.0.2</version>
</dependency>

版本范围 0.8.0 ~ 9.0.2,每次的版本更新都是伴随ES服务端的更新而更新,主要更新项是其所依赖的ES版本、Scala版本、Spark版本、hadoop版本。

Transport Client

介绍网址https://www.elastic.co/guide/en/elasticsearch/client/java-api/7.0/transport-client.html

从7.0开始标记弃用 ,8.0移除-- 官网不展示相关内容了,7标记弃用,但是还是随着服务端进行更新。此时建议Transport Client迁移至High Level Rest Client 。

依赖

xml 复制代码
<dependency>
    <groupId>org.elasticsearch.client</groupId>
    <artifactId>transport</artifactId>
    <version>7.17.29</version>
</dependency>

版本范围 5.0.0-alpha5~7.17.29。每次的版本更新都是伴随ES服务端的更新而更新,对服务端属于配套强依赖。

网页上没有类似ReleaseNote那样直接表明每次发布更新的内容,但是会列出支持的API。

High Level Rest Client

从Deprecated in 7.15.0.开始标记为弃用,建议High Level Rest Client 迁移至 Java API Client

介绍的网址https://www.elastic.co/guide/en/elasticsearch/client/java-rest/6.8/java-rest-high.html

依赖

xml 复制代码
<dependency>
    <groupId>org.elasticsearch.client</groupId>
    <artifactId>elasticsearch-rest-high-level-client</artifactId>
    <version>6.8.23</version>
</dependency>

版本范围 5.6.0 ~ 8.0.0-alpha2。High Level Rest Client的发布周期与 Elasticsearch 服务端相同。可将版本替换为所需的客户端版本。

网页上没有类似ReleaseNote那样直接表明每次发布更新的内容,但是会列出支持的API。

Low Level Rest Client

介绍的网址

版本从5.0至7.15使用的网址:https://www.elastic.co/guide/en/elasticsearch/client/java-rest/7.15/java-rest-low.html

版本从7.16至8.19使用的网址:https://www.elastic.co/guide/en/elasticsearch/client/java-api-client/7.16/java-rest-low.html

依赖

xml 复制代码
<dependency>
    <groupId>org.elasticsearch.client</groupId>
    <artifactId>elasticsearch-rest-client</artifactId>
    <version>8.19.4</version>
</dependency>

版本范围 5.6.0 ~ 9.1.4。Low Level Rest Client的发布周期与 Elasticsearch 服务端相同。

网页上没有类似ReleaseNote那样直接表明每次发布更新的内容,同样没有列出支持的API。Low Level Rest Client与所有 Elasticsearch 版本兼容,主要与HTTP协议和工具包有关系。

Java API Client

介绍网址

版本从7.16至8.19使用的网址:https://www.elastic.co/guide/en/elasticsearch/client/java-api-client/7.16/introduction.html

依赖

xml 复制代码
 <dependency>
      <groupId>co.elastic.clients</groupId>
      <artifactId>elasticsearch-java</artifactId>
      <version>7.16.3</version>
    </dependency>
    <dependency>
      <groupId>com.fasterxml.jackson.core</groupId>
      <artifactId>jackson-databind</artifactId>
      <version>2.12.3</version>
    </dependency>

版本范围 7.15.0 ~ 9.1.47.15.0是一个测试版本,不建议使用。

Elasticsearch 官网中一些更新的说明

release-highlights 发布亮点:一般跨多个版本才会出现,主要变化说明这个上面

Breaking changes 重大变化:包含一些会影响使用的变更

Enhancements 功能强化:对已有功能的加强

有时候有些变更其实没有很明确的区分Enhancements和Breaking changes

附录 Java API Client重大变更策略

Java API 客户端源代码是根据 Elasticsearch API 的正式规范生成的。该 API 规范内容繁多,尽管已针对数百个 Elasticsearch 测试文件进行了测试,但其可能与实际 API 存在差异,从而导致 Java API 客户端出现问题。

修复 API 规范中的这些差异会导致 Java API 客户端的代码更改,而其中一些更改可能需要更新您的应用程序的代码。

补丁版本中的重大变更

API 规范中的一些问题是指属性的类型不正确,例如,一个 long 类型属性应该是字符串,或者一个必需属性实际上是可选的。这些问题可能会导致 Java API 客户端无法正常工作,甚至抛出异常。

当规范问题被发现并解决后,可能需要在使用 Java API 客户端的应用程序中更新代码。即使在补丁版本(例如 7.17.0 → 7.17.1)中,此类重大更改也是可以接受的,因为它们为原本可能无法使用的 API 带来了稳定性。

次要版本中的重大变更

除了修复这些错误之外,API 规范也在不断完善,引入更精确的类型定义,以提高开发人员的舒适度并消除歧义。常用 API 的规范已经相当成熟,因此这些更改通常发生在不常用的 API 上。这些更改也可能导致需要代码更新的重大更改,这些更改在小版本(例如 8.0 → 8.1)中被认为是可接受的。

主要版本中的重大变更

主要版本(例如 7.x → 8.x)可能包含 API 规范和 Java API 客户端底层框架的更大规模重构。这些重构会经过仔细考量,并且仅在解锁新的重要功能或新开发时才会进行。

Elasticsearch API 稳定性保证

所有 Elasticsearch API 都具有稳定性指标,这些指标预示着潜在的变更。如果 API 是稳定的,则只会添加非重大变更。对于实验性 API,可以随时引入重大变更,这意味着这些变更也会反映在 Java API 客户端中。

相关推荐
一周困⁸天.8 小时前
Elasticsearch+Logstash+Filebeat+Kibana部署【7.1.1版本】
大数据·elk·elasticsearch·jenkins
数据与后端架构提升之路8 小时前
Elasticsearch 与 Faiss 联合驱动自动驾驶场景检索:高效语义匹配 PB 级视频数据
elasticsearch·自动驾驶·faiss
小雨的光9 小时前
QuickEsView
spring boot·elasticsearch·es可视化
xiaobangsky11 小时前
Elasticsearch安装使用
elasticsearch·jenkins
熙客11 小时前
Elasticsearch:分布式搜索引擎数据库
分布式·elasticsearch·搜索引擎
哦你看看15 小时前
Elasticsearch+Logstash+Filebeat+Kibana部署[7.17.3版本]
大数据·elasticsearch·搜索引擎
Hover_Z_快跑16 小时前
Docker 部署 Elasticsearch 8.12 + Kibana + Nginx 负载均衡
nginx·elasticsearch·docker
凯子坚持 c17 小时前
从零开始:开发一个仓颉三方库的完整实战
大数据·elasticsearch·搜索引擎
Empty_77721 小时前
Elasticsearch+Logstash+Filebeat+Kibana部署
大数据·elasticsearch·搜索引擎
敲上瘾1 天前
Elasticsearch从入门到实践:核心概念到Kibana测试与C++客户端封装
大数据·linux·c++·elasticsearch·搜索引擎·全文检索