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

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

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

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

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

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

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

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

读取逻辑简化为:

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

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

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

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

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

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

相关推荐
一缕猫毛40 分钟前
Flink demo代码
java·大数据·flink
Hello.Reader42 分钟前
Flink ML 基本概念Table API、Stage、Pipeline 与 Graph
大数据·python·flink
pale_moonlight1 小时前
十一、Flink基础环境实战
大数据·flink
beijingliushao1 小时前
103-Spark之Standalone环境测试
大数据·ajax·spark
西格电力科技1 小时前
光伏四可“可观”功能:光伏电站全景数字化的底层支撑技术
大数据·人工智能·架构·能源
TDengine (老段)1 小时前
从关系型数据库到时序数据库的思维转变
大数据·数据库·mysql·时序数据库·tdengine·涛思数据·非关系型数据库
木风小助理1 小时前
Flink CDC:构建实时数据入湖架构的核心引擎
大数据·架构·flink
管理大亨2 小时前
ELK + Redis Docker 企业级部署落地方案
大数据·运维·elk·elasticsearch·docker·jenkins
星川皆无恙2 小时前
基于知识图谱+深度学习的大数据NLP医疗知识问答可视化系统(全网最详细讲解及源码/建议收藏)
大数据·人工智能·python·深度学习·自然语言处理·知识图谱
PM老周2 小时前
DORA2025:如何用AI提升研发效能(以 ONES MCP Server 为例)
大数据·人工智能