学习Rust可以加信 xingzixi2
Meilisearch 团队近期发布了 v1.15 版本,为开发者带来了多个实用更新。同时,随着 Rust 社区的蓬勃发展,基于 Meilisearch 的搜索应用也日趋成熟,官方 SDK、社区 Demo 与 WebAssembly 支持不断完善。本文将全面介绍本次更新亮点,并结合 Rust 实践,展示如何构建现代、高性能的搜索体验。
Meilisearch v1.15 主要更新
精准数字搜索:关闭数字模糊匹配
数字字段(如手机号、邮编、ID 等)在 v1.15 中可以关闭错字容忍(typo tolerance),避免模糊命中错误结果。
- 关闭后,搜索
2024
不会误命中2025
或2004
; - 特别适用于包含大量唯一数值的数据集;
- 同时也能提升索引性能和搜索速度。
字符串支持字典顺序比较
字符串字段现在支持字典序比较操作,例如:
arduino
release_date < "2023-07-17"
同时也支持 <=
、>
、>=
、TO
等语法,适合处理日期、版本号、关键词等场景。
中文分词效果提升
Meilisearch 的分词器 Charabia 在本版本中显著增强了对中文的支持:
- 分词更准确;
- 更好地识别词边界和短语组合;
- 需要手动重新索引才能生效(可通过修改语言设置或更新 searchable 属性实现刷新)。
Rust 搜索应用的最佳实践
Meilisearch 在 Rust 生态中有着活跃的社区支持,早在 2019 年就有开发者构建了 Crates.io 的搜索镜像 Demo,展示了 Rust 和 Meilisearch 的良好适配性。
官方 Rust SDK 使用简介
Meilisearch 官方 SDK meilisearch-sdk
提供完整的索引管理与搜索功能,当前版本为 v0.28.0
,支持同步、异步与 WebAssembly 编译。
在 Cargo.toml
中引入:
ini
[dependencies]
meilisearch-sdk = "0.28.0"
示例代码:
rust
use meilisearch_sdk::{client::Client, search::Query};
#[tokio::main]
async fn main() {
let client = Client::new("http://localhost:7700", "masterKey");
let index = client.index("books");
index
.add_documents(&[Book { title: "Rust in Action" }], Some("id"))
.await
.unwrap();
let results = index.search().with_query("Rust").execute().await.unwrap();
println!("{:?}", results);
}
#[derive(serde::Serialize)]
struct Book {
title: String,
}
该 SDK 具有以下特性:
- 全异步支持;
- 内置错误处理与文档结构;
- 可用于服务端或浏览器(WASM 编译);
- 支持自定义排序、过滤、分页等高级功能。
WebAssembly 支持与前端集成
Meilisearch 的 Rust SDK 可编译为 WebAssembly,可直接用于构建浏览器端搜索体验,无需后端代理服务,适合:
- 静态网站全文搜索;
- Crates 浏览器项目;
- 文档系统搜索;
- 本地 AI 项目资源索引。
开始你的搜索项目
- 下载并运行 Meilisearch 或使用官方 Cloud 服务;
- 在 Rust 项目中引入
meilisearch-sdk
; - 选择适合的构建方式(服务端、WASM、异步);
- 构建文档索引,集成搜索功能;
- 根据需要使用拼写容忍、语言优化、过滤排序等高级功能。
致谢社区贡献者
Meilisearch v1.15 的发布离不开广大社区贡献者:
- 内核优化与代码贡献者:CodeMan62、shaokeyibb、HDT3213、shu-kitamura 等;
- 中文分词改进者:HDT3213、mosuka、luflow;
- SDK 与文档维护者们的持续努力。