Elasticsearch中的设置refresh_interval

在 Elasticsearch 中,refresh_interval 是一个 索引级别 的设置,用于控制 从内存缓冲区把新增/更新的文档刷到文件系统缓存(使其可搜索)的频率


🔍 一句话解释

它决定了 多久把"刚写入的数据"变成"立即可搜索的数据"


⚙️ 默认值

复制代码
"refresh_interval": "1s"
  • 默认每 1秒 执行一次 refresh。

  • 也就是说,默认情况下,新写入的文档最多延迟1秒就能被搜索到


🧪 参数说明

含义
"1s" 每1秒刷新一次(默认)
"30s" 每30秒刷新一次,降低I/O,提升写入吞吐量
"-1" 禁用自动刷新 ,需要手动调用 POST /my_index/_refresh 才能搜索到新数据

🧰 设置方法

创建索引时设置:
复制代码
PUT /my_index
{
  "settings": {
    "refresh_interval": "30s"
  }
}
动态修改(无需重启):
复制代码
PUT /my_index/_settings
{
  "refresh_interval": "30s"
}

✅ 使用场景建议

场景 推荐值 原因
实时搜索要求高(如电商搜索) "1s" 或更短 保证数据可见性
日志/批处理写入 "30s" 或更长 减少I/O,提升写入性能
大批量导入数据(如重建索引) 设置为 "-1",导入完成后手动 refresh 最大化写入吞吐量

🧠 小提示

  • 调大 refresh_interval 可以显著提升 bulk 写入速度,但会牺牲"实时性"。

  • 如果你在做 全量重建索引大批量导入 ,建议临时设置为 "-1",导入完再改回来。

相关推荐
A__tao19 小时前
Elasticsearch Mapping 一键生成 Java 实体类(支持嵌套 + 自动过滤注释)
java·python·elasticsearch
A__tao21 小时前
Elasticsearch Mapping 一键生成 Proto 文件(支持嵌套 + 注释过滤)
大数据·elasticsearch·jenkins
Devin~Y21 小时前
高并发电商与AI智能客服场景下的Java面试实战:从Spring Boot到RAG与向量数据库落地
java·spring boot·redis·elasticsearch·spring cloud·kafka·rag
Elastic 中国社区官方博客1 天前
使用 Jina-VLM 小型多语言视觉语言模型来和图片对话
大数据·人工智能·elasticsearch·语言模型·自然语言处理·jina
LDG_AGI1 天前
【搜索引擎】Elasticsearch(二):基于function_score的搜索排序
数据库·人工智能·深度学习·elasticsearch·机器学习·搜索引擎·推荐算法
历程里程碑1 天前
Protobuf总结
大数据·数据结构·elasticsearch·链表·搜索引擎
ACGkaka_1 天前
ES 学习(七)性能陷阱
大数据·学习·elasticsearch
LDG_AGI1 天前
【搜索引擎】Elasticsearch(三):基于script_score的自定义搜索排序
大数据·人工智能·深度学习·elasticsearch·机器学习·搜索引擎·推荐算法
Elastic 中国社区官方博客1 天前
如何使用 Mastra 和 Elasticsearch 构建具备代理能力的 AI 应用
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
LDG_AGI1 天前
【搜索引擎】Elasticsearch(一):索引创建、数据插入、请求示例
人工智能·深度学习·算法·elasticsearch·机器学习·搜索引擎·推荐算法