Rust × Elasticsearch官方 `elasticsearch` crate 上手指南

1 为什么选择官方 Rust 客户端?

  • 语义化兼容:客户端 主版本 与 ES 主版本 严格对应,8.x 客户端可对接任何 8.x 服务器;不存在跨主版本兼容承诺 (docs.rs)
  • 100% API 覆盖:稳定 API 全量映射,Beta/实验特性可按需开启
  • 异步高效:内建 reqwest + tokio,零额外胶水
  • Cloud Ready:支持 Cloud ID,几行代码直连 Elastic Cloud

2 快速开始

2.1 依赖配置

[dependencies]
elasticsearch = "9.0.0-alpha.1"  # 与 ES 9.x 对应
serde = { version = "1", features = ["derive"] }
serde_json = "1"
tokio = { version = "1", features = ["full"] }

可选 Cargo Feature

  • rustls-tls:纯 Rust TLS
  • beta-apis / experimental-apis:启用 Beta / 实验端点(自动包含 Beta) (docs.rs)

2.2 初始化客户端

use elasticsearch::{Elasticsearch, http::transport::Transport};#[tokio::main]
async fn main() -> anyhow::Result<()> {// 1) 默认本地 https://localhost:9200let client = Elasticsearch::default();// 2) 指定单节点 URLlet transport = Transport::single_node("https://es.local:9200")?;let client = Elasticsearch::new(transport);// 3) Cloud ID + Basic 认证use elasticsearch::auth::Credentials;let cloud_id = "cluster_name:.....";let creds = Credentials::Basic("elastic".into(), "pass".into());let transport = Transport::cloud(cloud_id, creds)?;let client = Elasticsearch::new(transport);Ok(())
}

3 核心操作全景

3.1 单条写入

use elasticsearch::IndexParts;
use serde_json::json;client.index(IndexParts::IndexId("tweets", "1")).body(json!({"user": "kimchy","message": "Hello, Elasticsearch!"})).send().await?;

3.2 Bulk 批量写入

use elasticsearch::{BulkParts, http::request::JsonBody};
use serde_json::json;let mut body: Vec<JsonBody<_>> = Vec::with_capacity(4);
body.push(json!({"index": {"_id": "1"}}).into());
body.push(json!({"user": "kimchy", "msg": "Bulk 1"}).into());
body.push(json!({"index": {"_id": "2"}}).into());
body.push(json!({"user": "forloop", "msg": "Bulk 2"}).into());let resp = client.bulk(BulkParts::Index("tweets")).body(body).send().await?;
assert!(!resp.json::<serde_json::Value>().await?["errors"].as_bool().unwrap());

3.3 搜索

use elasticsearch::SearchParts;
use serde_json::json;let resp = client.search(SearchParts::Index(&["tweets"])).from(0).size(10).body(json!({"query": { "match": { "message": "Elasticsearch rust" } }})).send().await?;let hits = resp.json::<serde_json::Value>().await?;
for h in hits["hits"]["hits"].as_array().unwrap() {println!("{:?}", h["_source"]);
}

3.4 Cat API —— 索引概览

use elasticsearch::cat::CatIndicesParts;
use serde_json::Value;let body = client.cat().indices(CatIndicesParts::Index(&["*"])).format("json").send().await?.json::<Value>().await?;for idx in body.as_array().unwrap() {println!("Index: {}", idx["index"]);
}

4 传输层高级定制

use elasticsearch::{http::transport::{SingleNodeConnectionPool, TransportBuilder},
};
use url::Url;let url = Url::parse("https://es.secure.local:9243")?;
let pool = SingleNodeConnectionPool::new(url);let transport = TransportBuilder::new(pool).cert_validation(false)          // 忽略证书验证(测试用).disable_proxy()                 // 跳过系统代理.build()?;let client = Elasticsearch::new(transport);

5 TLS 与 Feature 切换

方案配置适用场景
native-tls(默认)无需显式声明调用系统 OpenSSL / SChannel
rustls-tlsdefault-features = false, features = ["rustls-tls"]纯 Rust,可发往 Wasm、musl

6 版本兼容策略

  • 主版本必须一致;如 elasticsearch = "8" 必配合 ES 8.x
  • 小版本向前兼容:8.5 客户端可连 8.0 集群,但新增 API 不可调用;反之亦然 (docs.rs)

7 常见问题 FAQ

问题解决方案
invalid certificate使用 rustls-tls, 或 TransportBuilder::cert_validation(false) 暂时跳过
method not allowed核对 *_Parts 枚举是否匹配正确 URL 变体
如何同步调用?官方仅提供 异步 接口,需在 tokio::runtime 中 block_on
Beta/实验 API 404在 Cargo.toml 启用 beta-apis / experimental-apis

8 最佳实践

  1. 连接池复用:单实例 Elasticsearch 放全局,内部自动管理 HTTP 连接。
  2. Bulk 分片:控制单批 5–15 MB 或 5k 条,权衡内存与吞吐。
  3. 日志链路:启用 RUST_LOG=elasticsearch=trace 抓包定位慢查询。
  4. Cloud 部署:使用 Cloud ID + API Key,免维护证书、负载均衡。
  5. Typed Source:业务模型 #[derive(Serialize, Deserialize)],配合 serde_json::from_value 获取强类型文档。

9 结语

官方 elasticsearch crate 让 Rust 后端 也能享受与 Java/Python 同级的 ES 支持:全 API、强类型、异步高效
无论是打造实时日志管线、还是为 RAG 系统提供检索服务,都能凭借 Rust 的安全与性能优势,跑出新高度。

现在,就把老旧的 REST wrapper 替换掉,体验全新的 Rust × Elasticsearch 吧!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/pingmian/91099.shtml
繁体地址,请注明出处:http://hk.pswp.cn/pingmian/91099.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

怎样画流程图?符号与流程解构教程

在数字化办公和项目管理日益复杂的当下&#xff0c;流程图早已不是工程师、项目经理的专属工具&#xff0c;它正快速成为每一位职场人提升表达效率、理清工作逻辑的利器。无论是软件开发中的流程规范、产品设计阶段的用户路径&#xff0c;还是企业内部的审批流程、团队协作机制…

vue3 + vite || Vue3 + Webpack创建项目

1.vue3 vite搭建项目方法 &#xff08;需要提前装node,js&#xff09; 1. 使用官方 create-vite 工具&#xff08;推荐&#xff09; 1.使用npm----------------------------- npm create vuelatest2.使用pnpm----------------------------- pnpm create vuelatest3.使用yarn--…

Vue2-封装一个含所有表单控件且支持动态增减行列的表格组件

效果1. 无编辑权限&#xff1a;显示普通表格2. 有编辑权限&#xff1a;根据配置显示编辑控件3. 可以动态新增行&#xff0c;也可以动态新增列 核心代码无权限情况的核心代码<!-- 无编辑权限时显示普通表格 --><el-tablev-if"!hasEditPermission"ref"ta…

网络原理 - TCP/IP(一)

目录 1. 应用层&#xff1a;用户与网络的 “交互窗口” 1.1 应用层协议&#xff1a;规范交互的 “通用语言” 1.2 自定义协议&#xff1a;适配特殊需求的 “专属规则” 1.3 应用层数据格式&#xff1a;让数据 “说得明白” 1.3.1 XML&#xff1a;结构化但繁琐的 “老…

Orange的运维学习日记--16.Linux时间管理

Orange的运维学习日记–16. Linux时间管理 文章目录Orange的运维学习日记--16. Linux时间管理系统与硬件时钟时钟类型对比查看内核支持的时钟源本地时间调整使用 date 查看与设置一次性同步&#xff1a;ntpdate同步到硬件时钟&#xff1a;hwclock基于 systemd 的 timedatectl交…

Git 与 GitHub 的对比与使用指南

Git 与 GitHub 的对比与使用指南 在软件开发中&#xff0c;Git 和 GitHub 是两个密切相关但本质不同的工具。下面我将逐步解释它们的定义、区别、核心概念以及如何协同使用&#xff0c;确保内容真实可靠&#xff0c;基于广泛的技术实践。 1. 什么是 Git&#xff1f; Git 是一个…

20250726-4-Kubernetes 网络-Service DNS名称解析_笔记

一、Service DNS名称 1. 例题:通信需求 通信场景:项目A中的Pod需要与项目B中的Pod进行通信,直接使用Pod IP不可行,因为Pod IP会随着Pod生命周期变化。 解决方案:通过Service提供的稳定IP地址进行通信,不受Pod重建、扩容/缩容等操作影响。 2. CoreDNS介绍  基本功能…

vscode 登录ssh记住密码直接登录设置

第一种情况在系统已经生成密钥对的情况下&#xff1a;点击这里的设置第二步&#xff1a;第三步&#xff1a;没有填写的给填写一下第四步骤&#xff1a;保存后进入选择这个点开第五步&#xff1a;去Linux终端下输入这个命令就OK了echo "ssh-rsa内容" >> ~/.ssh/…

Nginx 动静分离配置(详细版)

本文介绍了Nginx 动静分离相关配置&#xff0c;主要包括了配置文件创建、配置示例、配置原理解析以及重新启用配置文件等等 本文目录1. 创建 Nginx 配置文件2. 配置示例3. 配置原理解析4. 启用配置文件并重新加载 Nginx1. 创建 Nginx 配置文件 在 /etc/nginx/sites-available …

C# CAN通信上位机系统设计与实现

C# CAN通信上位机系统设计与实现 C# CAN通信上位机程序&#xff0c;支持多种CAN适配器&#xff0c;提供数据收发、协议解析、数据可视化等功能。 using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; usi…

Ubuntu20.04子系统

常用 # 导出分发版到 E盘 wsl --export Ubuntu-20.04 E:\wsl-ubuntu20.04.tar # 注销原有分发版 wsl --unregister Ubuntu-20.04 # 导入到 E盘的新路径&#xff08;例如 E:\WSL\Ubuntu-20.04&#xff09; wsl --import Ubuntu-20.04 E:\WSL\Ubuntu-20.04 E:\wsl-ubuntu20.04.t…

【设计模式】状态模式 (状态对象(Objects for States))

状态模式&#xff08;State Pattern&#xff09;详解一、状态模式简介 状态模式&#xff08;State Pattern&#xff09; 是一种 行为型设计模式(对象行为型模式)&#xff0c;它允许一个对象在其内部状态改变时改变其行为。换句话说&#xff0c;对象看起来好像修改了它的类。 你…

工业前端组件库重构心法:如何让开发效率提升60%的交互模块设计逻辑

工业前端组件库重构心法&#xff1a;如何让开发效率提升60%的交互模块设计逻辑内容摘要在工业项目开发中&#xff0c;前端组件库是提升开发效率的关键。然而&#xff0c;许多团队的组件库存在设计不合理、维护困难等问题&#xff0c;导致开发效率低下。如果能够重构组件库&…

leetcode 74. 搜索二维矩阵

二分查找经典题目&#xff1b;根据矩阵的特点&#xff0c;不需要把矩阵拉成一维&#xff0c;二维转成一维映射关系为a[i]matrix[⌊i//n⌋][i%n]&#xff1b;然后开始二分查找&#xff0c;一直二分的收缩区间&#xff1b;class Solution:def searchMatrix(self, matrix: List[Li…

26考研英语词汇的逻辑笔记(Unit31-43)

行为UNIT 31词汇数量&#xff1a;274 词群数量&#xff1a;16 词群逻辑&#xff1a;行为举止 | 行为标准与原则 给予、收回 | 接受、允许、让步、拒绝 促进、鼓励 | 支持、帮助、资助 破坏相关 | 错误、改正 阻碍、打扰相关 | 禁止、阻止、限制 值得、有利、不利相关 | 有意、故…

Lua(数据库访问)

Lua 数据库访问方法Lua 本身不提供内置的数据库访问功能&#xff0c;但可以通过第三方库实现与多种数据库的交互。以下是常见的 Lua 数据库访问方法&#xff1a;使用 LuaSQL 库LuaSQL 是一个轻量级数据库访问库&#xff0c;支持多种数据库后端&#xff08;MySQL、PostgreSQL、S…

在 Dell PowerEdge T440 上通过 iDRAC9 安装 Proxmox VE

在 Dell PowerEdge T440 上通过 iDRAC9 安装 Proxmox VE 文章目录 在 Dell PowerEdge T440 上通过 iDRAC9 安装 Proxmox VE 1. 前置要求 1.1. 硬件信息(例) 1.2. 准备工作 2. 安装步骤 2.1. 登录 iDRAC9 2.2. 启动虚拟控制台 2.3. 挂载 Proxmox VE ISO 2.4. 设置服务器从虚拟…

window下MySQL安装(三)卸载mysql

window下MySQL安装&#xff08;三&#xff09;卸载mysql 卸载mysql数据库&#xff0c;停止服务&#xff0c;备份文件&#xff0c;删除mysql文件。结束。 停止mysql服务 以管理员身份打开命令提示符或 PowerShell&#xff1a; net stop <服务名称> 示例&#xff1a;net st…

Elasticsearch 深度分页问题与 `search_after` 解决方案

1. 引言 主题&#xff1a;介绍 Elasticsearch 深度分页问题的背景&#xff0c;强调其在处理大规模数据集时的性能瓶颈。核心问题&#xff1a;传统 from/size 分页方式在深层分页&#xff08;例如第500页&#xff09;时&#xff0c;因需要加载和丢弃大量文档&#xff0c;导致内存…

Spring Boot 2整合MyBatis Plus详细指南

1. 环境准备Spring Boot版本&#xff1a;2.x&#xff08;推荐2.7.x&#xff09;MyBatis Plus版本&#xff1a;3.5.x&#xff08;兼容Spring Boot 2&#xff09;数据库&#xff1a;MySQL 8.0&#xff08;其他数据库需调整驱动&#xff09;2. 创建项目并添加依赖在pom.xml中添加核…