【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 客户端中。

相关推荐
Elastic 中国社区官方博客8 小时前
如何减少 Elasticsearch 集群中的分片数量
大数据·数据库·elasticsearch·搜索引擎·全文检索
知识浅谈9 小时前
Elasticsearch 核心知识点全景解读
大数据·elasticsearch·搜索引擎
Komorebi_999910 小时前
Git 常用命令完整指南
大数据·git·elasticsearch
还是鼠鼠11 小时前
《黑马商城》Elasticsearch基础-详细介绍【简单易懂注释版】
java·spring boot·spring·elasticsearch·搜索引擎·spring cloud·全文检索
Cikiss14 小时前
图解 bulkProcessor(调度器 + bulkAsync() + Semaphore)
java·分布式·后端·elasticsearch·搜索引擎
极限实验室15 小时前
Elasticsearch 备份:方案篇
elasticsearch
Elastic 中国社区官方博客1 天前
Elasticsearch:使用推理端点及语义搜索演示
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
Elasticsearch2 天前
在 Elastic Cloud on Kubernetes 部署中的多租户示例架构
elasticsearch
INFINI Labs2 天前
如何使用 INFINI Gateway 对比 ES 索引数据
大数据·elasticsearch·gateway·easysearch