Elasticsearch Node.js 客户端的安装

一、快速安装

安装最新版本

bash 复制代码
npm install @elastic/elasticsearch

安装指定主版本(major)

bash 复制代码
npm install @elastic/elasticsearch@<major>

关于各主版本的支持情况,请查看 兼容性矩阵(Compatibility matrix)

二、Node.js 支持(Node.js support)

注意

最低支持的 Node.js 版本为 v18

客户端的版本遵循 Elastic Stack 的版本节奏 :即主版本、次版本和补丁发布都有固定的计划,这往往不与 Node.js 的发布时间线一致

为避免继续支持不安全或已停止维护(EOL)的 Node.js 版本,客户端会在次版本(minor)升级之间 逐步移除 对这些 EOL 版本的支持。通常,某个 Node.js 版本一旦进入 EOL,客户端仍会再多支持至少一个次版本 。如果你正在使用即将不再受支持的 Node.js 版本,日志里会看到提前两个次版本开始的警告提示。

除非你始终使用受支持的 Node.js 版本,否则建议在 package.json 中用 ~ 而不是 ^ 来声明客户端依赖。这样依赖会锁定到次版本线 而不是主版本线(例如用 ~7.10.0 而非 ^7.10.0)。

2.1. Node.js EOL 与客户端停止支持时间

Node.js 版本 Node.js EOL 日期 客户端停止支持(版本/时间)
8.x 2019 年 12 月 7.11(2021 年初)
10.x 2021 年 4 月 7.12(2021 年中)
12.x 2022 年 4 月 8.2(2022 年初)
14.x 2023 年 4 月 8.8(2023 年初)
16.x 2023 年 9 月 8.11(2023 年末)
18.x 2025 年 4 月 9.2(2025 年末)

三、兼容性矩阵(Compatibility matrix)

语言客户端具备前向兼容 能力:也就是说,客户端可以与更高或相同次版本 的 Elasticsearch 通信而不出错。但这不代表 客户端会自动支持 更高版本中新引入的功能;支持新功能需要发布新的客户端版本

例如:8.12 版本的客户端不会自动支持 Elasticsearch 8.13 的新功能;要使用这些功能需要 8.13 客户端

另外,Elasticsearch 语言客户端仅对默认发行版 提供有限的向后兼容,不作额外保证。

Elasticsearch 版本 客户端版本 Supported
9.x 9.x 9.x
8.x 8.x 8.x
7.x 7.x 7.17
6.x 6.x
5.x 5.x

四、浏览器(Browser)

警告

官方不支持浏览器环境 直接使用该客户端。这样会将你的 Elasticsearch 实例暴露给所有人,带来严重的安全风险。

我们建议你编写一个轻量级代理服务(例如使用本客户端的 Node.js 服务端),由代理与 Elasticsearch 通信。你可以参考相应的代理示例。

相关推荐
点云SLAM8 小时前
git使用详解和实战示例
大数据·git·elasticsearch·项目管理·开发工具·代码管理‘’
伍哥的传说11 小时前
开源协作白板 – 轻量级多用户实时协作白板系统 – 支持多用户绘图、文字编辑、图片处理
websocket·开源·node.js·canvas绘图·白板系统·实时协作·在线绘图
在未来等你15 小时前
Elasticsearch面试精讲 Day 3:分片与副本策略详解
大数据·分布式·elasticsearch·搜索引擎·面试
前端老鹰16 小时前
Node.js 命令行交互王者:inquirer 模块实战指南
后端·node.js
王廷胡_白嫖帝17 小时前
二、Git基础命令速查表
大数据·git·elasticsearch
Cdlblbq17 小时前
使用原生excel方式导入excel
node.js
在未来等你18 小时前
Elasticsearch面试精讲 Day 4:集群发现与节点角色
大数据·分布式·elasticsearch·搜索引擎·面试
王廷胡_白嫖帝18 小时前
一、Git与Gitee常见问题解答
git·elasticsearch·gitee
灵哎惹,凌沃敏18 小时前
git将当前分支推送到远端指定分支
大数据·git·elasticsearch
TheRedAce20 小时前
Node.js零基础到项目实战 Express+MySQL+Sequelize (二)
node.js