it编程 > 游戏开发 > ar

Elasticsearch 映射 fielddata 工作原理解析

7人参与 2025-06-11 ar

1.fielddata 是什么

fielddata 是 elasticsearch 中一种数据结构,用于在内存中缓存字段数据,主要服务于以下场景:

当需要对 text 字段或其他非 doc_values 支持的字段执行上述操作时,elasticsearch 需要将这些字段的值加载到内存中,这就是 fielddata 的作用。

2.fielddata 的工作原理

3.主要用法

3.1 启用 fielddata(通常在 text 字段上)

put my_index/_mapping
{
  "properties": {
    "my_text_field": { 
      "type":     "text",
      "fielddata": true
    }
  }
}

3.2 监控 fielddata 使用情况

get _nodes/stats/indices/fielddata?fields=*

3.3 清除 fielddata 缓存

post my_index/_cache/clear?fielddata=true

4.使用场景示例

示例 1:对 text 字段进行聚合

get my_index/_search
{
  "size": 0,
  "aggs": {
    "my_terms": {
      "terms": {
        "field": "my_text_field"  // 需要该字段启用 fielddata
      }
    }
  }
}

示例 2:对 text 字段进行排序

get my_index/_search
{
  "sort": [
    {
      "my_text_field": {
        "order": "asc"
      }
    }
  ]
}

5.fielddata 与 doc_values 的区别

特性fielddatadoc_values
构建时机查询时按需构建索引时预先构建
存储位置jvm 堆内存磁盘(操作系统缓存)
内存占用
适用字段类型主要为 text 字段主要为 keyword / numeric / date 等字段
默认启用text 字段默认禁用支持的字段默认启用

6.注意事项

7.最佳实践

"my_field": {
  "type": "text",
  "fields": {
    "keyword": {
      "type": "keyword"
    }
  }
}

然后对 my_field.keyword 进行操作。

监控 fielddata 内存使用,设置合理的熔断阈值。

到此这篇关于elasticsearch 映射 fielddata 工作原理解析的文章就介绍到这了,更多相关elasticsearch 映射 fielddata 内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

您想发表意见!!点此发布评论

推荐阅读

elasticsearch中的mapping简介(最新整理)

06-11

华为鸿蒙HarmonyOS 5.1官宣7月开启升级! 首批支持名单公布

06-11

如何自定义一个log适配器starter

06-10

5G网卡+高频内存! 七彩虹CVN X870 ARK FROZEN V14方舟主板评测

06-05

客制化新体验! 雷柏V700DIY-98机械键盘全面测评

06-03

性价比超越RTX 5070! 瀚铠VASTARMOR RX 9070 GRE合金白色显卡测评

06-03

猜你喜欢

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论