学技术学英语:elasticsearch查询的两阶段queryingfetching
To understand Elasticsearch’s distributed search, let’s take a moment to understand how querying and fetching work. Unlike simple CRUD tasks, distributed search is like navigating through a maze of shards spread across the cluster.
In Elasticsearch, CRUD operations handle individual documents identified by their unique index, type, and routing-value (usually the document’s _id). However, search queries are more complex. They don’t have a fixed destination and must search through every shard in the index or indices to locate potential matches.
However, discovering matching documents marks just the beginning. The search API needs to combine results from various shards into a unified, organized list before displaying them to the user. This initiates the two-step process of querying and fetching.
By default, Elasticsearch utilizes a search method known as “Query Then Fetch.” This approach progresses through the following steps:
- Client sent a query to Elasticsearch
- Broadcast the query to each shard
- Find all matching documents and calculate scores using local Term/Document Frequencies
- Build a priority queue of results (sort, pagination with from/to, etc)
- Return metadata about the results to requesting node. Note, the actual document is not sent yet, just the scores
- Scores from all the shards are merged and sorted on the requesting node, docs are selected according to query criteria
- Finally, the actual docs are retrieved from individual shards where they reside.
- Results are returned to the client
Note: Coordinator node responsible for the steps 1,2, and 8.
Query Phase (3,4,5,6): the search query is sent to every shard, initiating local execution and the creation of a priority queue containing matching documents.

Fetch Phase (7): while the query phase identifies relevant documents, the fetch phase is responsible for fetching the actual documents from their respective shards.

This divided method guarantees effective and scalable search operations in a distributed setting. In the query phase, the search query navigates through each shard copy (primary or replica shards) to initiate local searches and compile a prioritized list of matching documents. This phase marks the initial step in refining the search results.
The fetch phase, resulting in the delivery of desired search outcomes. This phase acts as a bridge between query execution and result retrieval, ensuring the thoroughness of the search process.
Additional information:
Enabling Elasticsearch’s slow logs separately for query and fetch phases enables precise monitoring and optimization of search performance. Administrators can pinpoint potential bottlenecks and adjust system parameters by establishing thresholds for query and fetch durations separately.
For instance, configuring slow logs with specific thresholds for query and fetch phases can be done as follows:
PUT *,-.*/_settings
{"index.search.slowlog.threshold.query.warn": "1s","index.search.slowlog.threshold.fetch.warn": "100ms"
}#or with curlcurl -XPUT "http://localhost:9200/*,-.*/_settings" -H "Content-Type: application/json" -d'
{"index.search.slowlog.threshold.query.warn": "1s","index.search.slowlog.threshold.fetch.warn": "100ms"
}'
Elasticsearch query vs fetch times
It’s expected to see way more less fetch time compared to query time. Here is a topic that created in elastic discuss about the speed.
中文总结:
-
分布式搜索的两阶段过程:
-
Elasticsearch 的分布式搜索分为 查询阶段(Query Phase) 和 获取阶段(Fetch Phase)。
-
查询阶段:搜索请求广播到每个分片,分片本地执行查询并返回匹配文档的元数据(如评分)。
-
获取阶段:根据查询阶段的结果,从各个分片获取实际的文档内容。
-
-
查询阶段的工作流程:
-
客户端发送查询请求到协调节点(Coordinator Node)。
-
协调节点将查询广播到索引的每个分片(主分片或副本分片)。
-
每个分片本地执行查询,计算文档评分,并构建一个优先级队列。
-
分片返回元数据(如文档 ID 和评分)到协调节点,协调节点合并和排序所有分片的结果。
-
-
获取阶段的工作流程:
-
协调节点根据查询阶段的结果,向相关分片请求实际的文档内容。
-
分片返回文档内容,协调节点将最终结果返回给客户端。
-
-
慢日志监控:
-
可以为查询阶段和获取阶段分别启用慢日志,以监控和优化搜索性能。
-
示例配置:
json
复制
PUT *,-.*/_settings {"index.search.slowlog.threshold.query.warn": "1s","index.search.slowlog.threshold.fetch.warn": "100ms" }
-
-
查询时间与获取时间的对比:
-
通常情况下,获取时间(Fetch Time)远低于 查询时间(Query Time),因为查询阶段涉及更多的计算和排序操作。
-
相关文章:
学技术学英语:elasticsearch查询的两阶段queryingfetching
To understand Elasticsearch’s distributed search, let’s take a moment to understand how querying and fetching work. Unlike simple CRUD tasks, distributed search is like navigating through a maze of shards spread across the cluster. In Elasticsearch, CRU…...
Linux_线程互斥
互斥的相关概念 共享资源:指多个进程或线程可以共同访问和操作的资源临界资源:被保护的共享资源就叫做临界资源临界区:每个线程内部,访问临界资源的代码,就叫做临界区互斥:任何时刻,互斥保证有…...
基于 NodeJs 一个后端接口的创建过程及其规范 -- 【elpis全栈项目】
基于 NodeJs 一个后端接口的创建过程及其规范 一个接口的诞生: #mermaid-svg-46HXZKI3fdnO0rKV {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-46HXZKI3fdnO0rKV .error-icon{fill:#552222;}#mermaid-sv…...
企业知识库提升企业核心竞争力促进团队协作和知识分享
内容概要 在快速发展的数字化时代,企业知识库的构建与运用变得愈发重要。其重要性不仅体现在信息的集中管理上,更在于推动企业整体竞争力的提升。一个高效的知识库可以作为团队合作的重要平台,促进不同部门之间的信息交流与协作,…...
C++ unordered_map和unordered_set的使用,哈希表的实现
文章目录 unordered_map,unorder_set和map ,set的差异哈希表的实现概念直接定址法哈希冲突哈希冲突举个例子 负载因子将关键字转为整数哈希函数除法散列法/除留余数法 哈希冲突的解决方法开放定址法线性探测二次探测 开放定址法代码实现 哈希表的代码 un…...
games101-作业3
由于此次试验需要加载模型,涉及到本地环节,如果是windows系统,需要对main函数中的路径稍作改变: 这么写需要: #include "windows.h" 该段代码: #include "windows.h" int main(int ar…...
【Block总结】高效多尺度注意力EMA,超越SE、CBAM、SA、CA等注意力|即插即用
论文信息 标题: Efficient Multi-Scale Attention Module with Cross-Spatial Learning 作者: Daliang Ouyang, Su He, Guozhong Zhang, Mingzhu Luo, Huaiyong Guo, Jian Zhan, Zhijie Huang 论文链接: https://arxiv.org/pdf/2305.13563v2 GitHub链接: https://github.co…...
Pwn 入门核心工具和命令大全
一、调试工具(GDB 及其插件) GDB 启动调试:gdb ./binary 运行程序:run 或 r 设置断点:break *0x地址 或 b 函数名 查看寄存器:info registers 查看内存:x/10wx 0x地址 (查看 10 个 …...
探索AI(chatgpt、文心一言、kimi等)提示词的奥秘
大家好,我是老六哥,我正在共享使用AI提高工作效率的技巧。欢迎关注我,共同提高使用AI的技能,让AI成功你的个人助理。 "AI提示词究竟是什么?" 这是许多初学者在接触AI时的共同疑问。 "我阅读了大量关于…...
利用飞书机器人进行 - ArXiv自动化检索推荐
相关作者的Github仓库 ArXivToday-Lark 使用教程 Step1 新建机器人 根据飞书官方机器人使用手册,新建自定义机器人,并记录好webhook地址,后续将在配置文件中更新该地址。 可以先完成到后续步骤之前,后续的步骤与安全相关&…...
小白爬虫冒险之反“反爬”:无限debugger、禁用开发者工具、干扰控制台...(持续更新)
背景浅谈 小白踏足JS逆向领域也有一年了,对于逆向这个需求呢主要要求就是让我们去破解**“反爬机制”**,即反“反爬”,脚本处理层面一般都是decipher网站对request设置的cipher,比如破解一个DES/AES加密拿到key。这篇文章先不去谈…...
Ubuntu中MySQL安装-02
服务器端安装 安装服务器端:在终端中输入如下命令,回车后,然后按照提示输入 sudo apt-get install mysql-server 当前使用的ubuntu镜像中已经安装好了mysql服务器端,无需再安装,并且设置成了开机自启动服务器用于接…...
大数据相关职位介绍之一(数据分析,数据开发,数据产品经理,数据运营)
大数据相关职位介绍之一 随着大数据、人工智能(AI)和机器学习的快速发展,数据分析与管理已经成为各行各业的重要组成部分。从互联网公司到传统行业的数字转型,数据相关职位在中国日益成为推动企业创新和提升竞争力的关键力量。以…...
使用DeepSeek API生成Markdown文件
DeepSeek技术应用与代码实现 一、DeepSeek简介 DeepSeek是一款强大的人工智能写作助手,能够根据用户输入的提示(Prompt)快速生成高质量的文章。它不仅支持批量生成文章,还能通过智能分段、Markdown转HTML等功能优化内容。此外&…...
java多线程学习笔记
文章目录 关键词1.什么是多线程以及使用场景?2.并发与并行3.多线程实现3.1继承 Thread 类实现3.2Runnable 接口方式实现3.3Callable接口/Future接口实现3.4三种方式总结 4.常见的成员方法(重点记忆)94.1setName/currentThread/sleep要点4.2线程的优先级…...
Manticore Search,新一代搜索引擎之王
吊打ES,新一代搜索引擎之王 概述 Manticore Search 是一个开源的分布式搜索引擎,专注于高性能和低延迟的搜索场景。 它基于 Sphinx 搜索引擎开发,继承了 Sphinx 的高效索引和查询能力,并在分布式架构、实时搜索、易用性等方面进…...
【MySQL】数据类型与表约束
目录 数据类型分类 数值类型 tinyint类型 bit类型 小数类型 字符串类型 日期和时间类型 enum和set 表的约束 空属性 默认值 列描述 zerofill 主键 自增长 唯一键 外键 数据类型分类 数值类型 tinyint类型 MySQL中,整形可以是有符号和无符号的&…...
CAG技术:提升LLM响应速度与质量
标题:CAG技术:提升LLM响应速度与质量 文章信息摘要: CAG(Cache-Augmented Generation)通过预加载相关知识到LLM的扩展上下文中,显著减少了检索延迟和错误,从而提升了响应速度和质量。与传统的R…...
上位机知识篇---Linux源码编译安装链接命令
文章目录 前言第一部分:Linux源码编译安装1. 安装编译工具2. 下载源代码3. 解压源代码4. 配置5. 编译6. 测试(可选)7. 安装8. 清理(可选)9.注意事项 第二部分:链接命令硬链接(Hard Link…...
科研绘图系列:R语言绘制线性回归连线图(line chart)
禁止商业或二改转载,仅供自学使用,侵权必究,如需截取部分内容请后台联系作者! 文章目录 介绍加载R包数据下载导入数据数据预处理画图保存图片系统信息参考介绍 科研绘图系列:R语言绘制线性回归连线图(line chart) 加载R包 library(tidyverse) library(ggthemes) libra…...
零售业供应链数字化实战:拆解爱室丽Ashley的EDI项目如何用3周快速上线(AS2+API方案解析)
零售业供应链数字化实战:拆解爱室丽Ashley的EDI项目如何用3周快速上线(AS2API方案解析) 在家居零售行业,供应链效率直接决定了企业的市场竞争力。当订单响应速度慢、库存信息滞后成为常态时,头部企业早已开始通过数字化…...
不止于安装:用FreeSurfer 7.1.0和Python(mne库)把你的MRI数据变成可编辑的3D头模型
从MRI到3D头模型:FreeSurfer与Python的深度整合实战 在神经影像研究领域,将原始MRI数据转化为可编辑的三维模型是一个关键步骤。传统流程往往止步于数据处理阶段,而本文将带您探索如何利用FreeSurfer 7.1.0与Python生态(特别是mne…...
AI智能体技能库:工程化AI助手,提升团队开发效率与一致性
1. 项目概述:一个为工程团队设计的AI智能体技能与规则库如果你和我一样,每天都在和Claude Code、Cursor这类AI编程助手打交道,那你一定也经历过这种循环:每次开启一个新会话,都要重新描述一遍你的代码审查标准、项目架…...
从实战出发:用BurpSuite和PHPStudy复现upload-labs靶场19关的5种典型绕过姿势
从实战出发:用BurpSuite和PHPStudy复现upload-labs靶场19关的5种典型绕过姿势 在渗透测试的学习过程中,文件上传漏洞一直是Web安全领域的重要课题。upload-labs靶场作为专门针对上传漏洞设计的实战环境,包含了19种不同类型的上传绕过场景。本…...
OmniTransfer框架:视频风格迁移的时空统一解决方案
1. 项目概述:当视频处理遇上时空统一在多媒体处理领域,视频迁移技术一直面临着时空维度割裂的痛点。传统方法往往将时间序列分析和空间特征提取作为两个独立模块处理,导致视频风格迁移、内容转换等任务出现帧间闪烁、运动失真等问题。OmniTra…...
自动驾驶轨迹预测避坑指南:为什么你的模型对路口转向不敏感?聊聊HiVT的旋转不变性设计
自动驾驶轨迹预测避坑指南:HiVT如何用旋转不变性解决路口转向难题 环岛中央,一辆测试车正以30公里时速平稳行驶。工程师们紧盯着屏幕上的预测轨迹曲线——突然,当车辆开始左转时,模型输出的未来路径像被无形力量拉扯般偏离真实轨迹…...
当优化算法遇上自然灵感:聊聊蜣螂优化(DBO)背后的生物行为与工程思维
当优化算法遇上自然灵感:聊聊蜣螂优化(DBO)背后的生物行为与工程思维 在科技与自然的交汇处,总有一些令人惊叹的灵感闪现。想象一下,一群在非洲草原上滚着粪球的蜣螂,竟能启发工程师设计出解决复杂优化问题…...
ctfileGet终极指南:城通网盘直连解析的免费神器
ctfileGet终极指南:城通网盘直连解析的免费神器 【免费下载链接】ctfileGet 获取城通网盘一次性直连地址 项目地址: https://gitcode.com/gh_mirrors/ct/ctfileGet 还在为城通网盘的龟速下载而烦恼吗?每次下载都要等待验证码,速度还被…...
Godot SpriteMesh插件:将2D像素精灵转换为3D网格的完整指南
1. 项目概述:当2D像素精灵遇见3D世界在独立游戏开发,尤其是像素风游戏的制作中,我们常常会遇到一个有趣的挑战:如何将那些精美的2D像素精灵,自然地融入到3D场景中?传统的做法是使用Sprite3D节点,…...
别再用Delay了!STM32按键控制LED的3种高级写法(中断、状态机、滤波)
别再用Delay了!STM32按键控制LED的3种高级写法(中断、状态机、滤波) 在嵌入式开发中,按键控制LED是最基础的功能之一,但很多开发者止步于简单的延时消抖实现。这种传统方法虽然容易理解,却存在实时性差、资…...
