2024.2.25 -ElasticSearch 进阶

倒排索引

Elasticsearch的倒排索引机制是通过将文档中出现的词汇与它们所在的文档ID关联起来,实现快速查找包含特定词汇的文档。下面是一个具体的例子来说明倒排索引的工作原理:

假设我们有一个简单的文章集合,包含以下三篇文章:

  1. 文章A:标题为"新冠病毒疫情最新动态",内容为"关于全球COVID-19疫情的最新进展报告"

  2. 文章B:标题为"春季流感预防措施",内容为"如何在春季有效预防流感病毒传播"

  3. 文章C:标题为"疫苗接种的重要性",内容为"讨论不同类型的疫苗及其在防疫中的关键作用"

**构建倒排索引过程:**

对于每个文档,Elasticsearch会执行以下步骤:

  • 分词(Tokenization):对文档的内容进行分词处理。例如,文章A的标题和内容分别会被分成如下的关键词:

  • 标题:"新冠"、"病毒"、"疫情"、"最新"、"动态"

  • 内容:"全球"、"COVID-19"、"疫情"、"最新"、"进展"、"报告"

  • 创建倒排索引条目:

  • 对于每个唯一词汇,记录它出现在哪些文档以及在文档中的位置信息:

  • "新冠" -> [文档A, 标题]

  • "病毒" -> [文档A, 标题], [文档A, 内容]

  • "疫情" -> [文档A, 标题], [文档A, 内容]

  • ...

  • "预防" -> [文档B, 标题]

  • "疫苗" -> [文档C, 标题]

**查询使用倒排索引:**

现在,如果我们想要搜索包含关键词"疫情"的所有文章,Elasticsearch可以直接查看倒排索引,找到关键词"疫情"对应的文档列表,即:

  • "疫情" -> [文档A, 标题], [文档A, 内容]

因此,搜索引擎立即知道文档A包含了这个词,并且可以在毫秒级的时间内返回搜索结果。

总结来说,Elasticsearch的倒排索引使得无需扫描整个文档集合就能迅速定位到含有特定词汇的文档,极大地提高了全文检索的速度和效率。

ES的架构

角色:client Esmaster

相关推荐
武子康4 小时前
大数据-239 离线数仓 - 广告业务实战:Flume 导入日志到 HDFS,并完成 Hive ODS/DWD 分层加载
大数据·后端·apache hive
洛森唛20 小时前
Elasticsearch DSL 查询语法大全:从入门到精通
后端·elasticsearch
字节跳动数据平台1 天前
代码量减少 70%、GPU 利用率达 95%:火山引擎多模态数据湖如何释放模思智能的算法生产力
大数据
得物技术1 天前
深入剖析Spark UI界面:参数与界面详解|得物技术
大数据·后端·spark
武子康1 天前
大数据-238 离线数仓 - 广告业务 Hive分析实战:ADS 点击率、购买率与 Top100 排名避坑
大数据·后端·apache hive
武子康2 天前
大数据-237 离线数仓 - Hive 广告业务实战:ODS→DWD 事件解析、广告明细与转化分析落地
大数据·后端·apache hive
大大大大晴天2 天前
Flink生产问题排障-Kryo serializer scala extensions are not available
大数据·flink
Elasticsearch3 天前
如何使用 Agent Builder 排查 Kubernetes Pod 重启和 OOMKilled 事件
elasticsearch
Elasticsearch4 天前
通用表达式语言 ( CEL ): CEL 输入如何改进 Elastic Agent 集成中的数据收集
elasticsearch
武子康4 天前
大数据-236 离线数仓 - 会员指标验证、DataX 导出与广告业务 ODS/DWD/ADS 全流程
大数据·后端·apache hive