news 2026/6/10 14:25:24

Elasticsearch 搜索性能优化实战指南(生产级)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Elasticsearch 搜索性能优化实战指南(生产级)

Elasticsearch 搜索性能优化实战指南(生产级)


一、索引设计进阶(决定上限)

1️⃣ 分片数的工程化计算方法(可落地)

经验公式:

目标分片数 ≈ 总数据量 / 30GB

示例:

  • 预计 1 年数据量:3TB
  • 3TB ≈ 3000GB
  • 分片数 ≈ 3000 / 30 ≈ 100 个主分片

建议拆分:

  • 按时间滚动索引(Index Lifecycle)
  • 每日 / 每周索引
  • 每个索引 3~6 个主分片
PUT logs-2026.01.31 { "settings": { "number_of_shards": 3, "number_of_replicas": 1 } }

✅ 核心原则

  • 分片 ≠ 越多越好
  • 查询 = 跨分片并发 + 合并成本

2️⃣ Mapping 防踩坑清单(90% 性能问题源头)

❌ 常见错误
  • 所有字符串都用 text
  • text + keyword 默认双字段
  • 大字段开启 fielddata
✅ 推荐模板
"status": { "type": "keyword", "norms": false }, "title": { "type": "text", "analyzer": "ik_max_word", "search_analyzer": "ik_smart" }

高频优化点:

  • 不参与搜索的字段:index: false
  • 不排序字段:doc_values: false
  • 不需要评分:关闭 norms

二、查询优化实战(最容易立竿见影)

3️⃣ Filter + Query 正确组合姿势

{ "query": { "bool": { "must": [ { "match": { "title": "elasticsearch" }} ], "filter": [ { "term": { "status": "ONLINE" }}, { "range": { "create_time": { "gte": "now-7d" }}} ] } } }</
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/9 19:50:39

Redis持久化存储

1、简介 Redis的高性能是由于其将所有数据都存储在了内存中&#xff0c;为了使Redis在重启之后仍能保证数据不丢失&#xff0c;需要将数据从内存中同步到硬盘中&#xff0c;这一过程就是持久化。 Redis支持两种方式的持久化&#xff0c;一种是RDB方式&#xff0c;一种是AOF方式…

作者头像 李华
网站建设 2026/6/10 10:51:59

Java毕设选题推荐:基于java+springboot的Web的毕业设计选题系统基于Java Web的毕业设计选题管理系统的设计与实现【附源码、mysql、文档、调试+代码讲解+全bao等】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/6/10 12:32:17

长沙不拼速度拼“厚度”

一个产业或者企业在从要素驱动向创新驱动过渡时&#xff0c;往往会经历增速换挡期、高波动向低波动的转换期。这是经济周期理论的一个观点&#xff0c;即便是华尔街看企业&#xff0c;也经常强调质量比增速更重要。 而如果放大到一个地区&#xff0c;这个逻辑还成立吗&#xf…

作者头像 李华
网站建设 2026/6/9 22:49:56

文明6 MOD制作入门:解密官方阿兹特克配置文件

&#x1f4d6; 前言 如果你是刚开始接触文明6 MOD制作的新手&#xff0c;看到官方复杂的XML文件可能会感到一头雾水。今天&#xff0c;我们就来深入解析阿兹特克文明的官方配置文件&#xff0c;用通俗易懂的方式带你入门MOD制作&#xff01; &#x1f3af; 文件概览 这个文件…

作者头像 李华