【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:快速近似 ES|QL - 第一部分
大数据·运维·数据库·elasticsearch·搜索引擎·全文检索
地瓜伯伯17 小时前
SpringBoot项目整合Elasticsearch启动失败的常见错误总结
spring boot·elasticsearch·spring cloud
持续进阶的开发者18 小时前
工作中常用Elasticsearch命令汇总
大数据·elasticsearch·搜索引擎
杰克尼19 小时前
天机学堂项目总结(day1~day2)
大数据·jvm·spring·elasticsearch·搜索引擎·spring cloud·mybatis
dyxal21 小时前
Windows 下 Git 离线安装与 VS Code 便携版集成完全指南
windows·git·elasticsearch
8Qi81 天前
Elasticsearch实战篇:索引库、文档与JavaRestClient操作指南
java·大数据·elasticsearch·搜索引擎·微服务·架构·springcloud
Elasticsearch2 天前
Streams 如何在几秒内生成日志管道
elasticsearch
历程里程碑2 天前
二叉树---翻转二叉树
开发语言·c++·elasticsearch·链表·搜索引擎·tornado·dash
海兰2 天前
Elasticsearch 容量规划与性能优化完全指南
大数据·elasticsearch·性能优化
梦想与想象-广州大智汇2 天前
告别“内存刺客”!sync-canal-go:轻量mysql实时同步数据到Elasticsearch‌,clickhouse,redis
mysql·elasticsearch·golang·同步数据