es的内部数据存储逻辑,读取逻辑

Elasticsearch的内部数据存储逻辑和读取逻辑是非常复杂的,但是可以概括为以下几点:

  1. 索引(Index): 一个索引就是一个文档的容器,它包含了很多文档。

  2. 分片(Sharding): 为了处理大量数据,Elasticsearch会将一个索引分成多个部分,每个部分就是一个分片。

  3. 副本(Replica): 每个分片可以有多个副本,以提供高可用性。

  4. Translog: 一个内部的日志文件,用于保存尚未被索引的或尚未被确认的数据变更。

  5. 段(Segment): 数据被分割成段,段是Elasticsearch最小的搜索单元。

  6. 内存缓冲区: 用于批量写入的内存缓冲区,它会在合适的时候刷新到磁盘。

读取逻辑简化为:

  • 客户端发送请求到Elasticsearch节点。

  • 节点根据请求的信息定位到包含所需数据的分片。

  • 如果需要,节点会从主分片同步数据到副本分片。

  • 节点将请求执行在本地分片上,并返回结果给客户端。

具体的读取操作涉及到分片寻址、搜索和返回结果,这些操作都是分布式和近实时的。

由于Elasticsearch的内部机制复杂,具体细节涉及到很多优化技术,例如:Lucene的倒排索引、段合并、缓存机制等。

相关推荐
老蒋新思维13 小时前
创客匠人 2025 峰会启示:AI 重构知识变现,从内容输出到资产运营
大数据·人工智能·tcp/ip·重构·创始人ip·创客匠人·知识变现
嘉禾望岗50313 小时前
spark standalone模式HA部署,任务失败重提测试
大数据·分布式·spark
Dxy123931021613 小时前
Elasticsearch数据更新简介
大数据·elasticsearch·搜索引擎
TDengine (老段)13 小时前
TDengine COLS 函数用户手册
大数据·数据库·物联网·时序数据库·iot·tdengine
B站计算机毕业设计之家13 小时前
电商数据实战:python京东商品爬取与可视化系统 大数据 Hadoop spark 优秀项目(源码)✅
大数据·hadoop·python·机器学习·spark·echarts·推荐算法
啊吧怪不啊吧13 小时前
贪心算法(局部最优实现全局最优)第二篇
大数据·算法·leetcode·贪心算法
e***582313 小时前
【分布式】Hadoop完全分布式的搭建(零基础)
大数据·hadoop·分布式
智能化咨询14 小时前
(66页PPT)某著名企业XX集团数据分析平台建设项目方案设计(附下载方式)
大数据·人工智能·数据分析
新诺韦尔API14 小时前
手机在网时长查询接口对接全流程详解
大数据·网络·api
REDcker15 小时前
搜索引擎高级搜索运算符完全指南 Google 谷歌/Bing 必应/Baidu 百度
搜索引擎·百度·google·谷歌·bing·baidu·必应