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

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

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

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

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

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

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

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

读取逻辑简化为:

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

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

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

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

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

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

相关推荐
德育处主任Pro1 分钟前
『NAS』在群晖部署无广聚合搜索引擎-SearXNG
搜索引擎·nas
hughnz7 分钟前
走进贝克休斯油田技术服务世界
大数据·人工智能·能源·钻井
GlobalInfo9 分钟前
汽车电感式位置传感器行业单项冠军申请趋势分析报告
大数据·人工智能·汽车
zandy101111 分钟前
企业合同管理系统选型全指南:专业 CLM 系统选型核心逻辑与实操框架
大数据·人工智能
数据小玩子11 分钟前
精准归因:如何量化分析光伏电站的每一分发电损失?
大数据·人工智能·数据可视化·助睿数智·光伏电站运营
金牌归来发现妻女流落街头11 分钟前
【用 Java API Client 操作 Elasticsearch】
java·elasticsearch·jenkins
TDengine (老段)16 分钟前
TDengine IDMP 组态面板 —— 连线
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
Zzj_tju16 分钟前
AI+医疗进阶:多智能体系统怎么协作做诊断、总结与质控?
大数据·人工智能
MonkeyKing_sunyuhua17 分钟前
金蝶,用友,东软等传统软件公司怎么应对AI改革
大数据·人工智能
岁岁种桃花儿23 分钟前
Flink从入门到上天系列第十九篇:Flink当中的容错机制
大数据·flink