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

相关推荐
VXHAruanjian88825 分钟前
以智促效,释放创新力量,RPA助力企业全面自动化变革
大数据·人工智能
哦你看看2 小时前
Elasticsearch+Logstash+Filebeat+Kibana部署[7.17.3版本]
大数据·elasticsearch·搜索引擎
小鹿学程序3 小时前
搭建hadoop集群
大数据·hadoop·分布式
Hover_Z_快跑3 小时前
Docker 部署 Elasticsearch 8.12 + Kibana + Nginx 负载均衡
nginx·elasticsearch·docker
ApacheSeaTunnel3 小时前
LLM 时代,DataAgent × WhaleTunnel 如何将数据库变更瞬时 “转译” 为洞察?
大数据·ai·开源·llm·数据同步·白鲸开源·whaletunnel
凯子坚持 c4 小时前
从零开始:开发一个仓颉三方库的完整实战
大数据·elasticsearch·搜索引擎
人大博士的交易之路5 小时前
今日行情明日机会——20251104
大数据·数据挖掘·数据分析·缠论·涨停回马枪·道琼斯结构
John Song5 小时前
用zookpeer搭建Hadoop的HA集群,组件启动的启动顺序是什么?
大数据·hadoop·debian
Hello.Reader5 小时前
Flink Table API & SQL 概念、常用 API 与工程落地
大数据·sql·flink
SEO_juper6 小时前
AI SEO实战:利用人工智能提升网站排名与流量的完整策略
人工智能·搜索引擎·百度·ai·seo·数字营销