news 2026/4/3 3:12:04

ES理论:索引字段类型选择

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
ES理论:索引字段类型选择

文章目录

  • 前言
  • 汇总
  • 索引配置项设计
  • 索引字段类型
    • keyword
    • text类型
    • 多字段映射 (Multi-fields)
    • **path_analyzer**
    • 数值类型 float
    • 日期类型
    • tags字段设计
    • 自定义路径分析器
  • 资料获取

前言

博主介绍:✌目前全网粉丝4W+,csdn博客专家、Java领域优质创作者,博客之星、阿里云平台优质作者、专注于Java后端技术领域。

涵盖技术内容:Java后端、大数据、算法、分布式微服务、中间件、前端、运维等。

博主所有博客文件目录索引:博客目录索引(持续更新)

CSDN搜索:长路

视频平台:b站-Coder长路

汇总

  1. keyword vs text
    • keyword:精确匹配,用于过滤、聚合、排序
    • text:全文搜索,用于内容检索
  1. 数值类型选择
    • integer:整数值,如状态码、等级
    • long:大数值,如文件大小、价格
    • date:时间日期,支持范围查询

索引配置项设计

"settings":{"number_of_shards":15,"number_of_replicas":1,"refresh_interval":"30s"}
  • shards: 15 - 数据分片数,影响并行处理能力
  • replicas: 1 - 每个分片的副本数,影响高可用性
  • refresh_interval: 30s - 索引刷新间隔,影响数据实时性

索引字段类型

keyword

keyword类型:

"id":{"type":"keyword"}
  • 含义:用于精确值匹配,不分词
  • 适用场景:ID、状态码、标签等需要精确匹配的字段
  • 特点:支持聚合、排序,性能优于text类型

text类型

"fileName":{"type":"text","analyzer":"ik_max_word","search_analyzer":"ik_smart"}
  • 含义:全文搜索字段,会被分词
  • analyzer:索引时使用的分词器
  • search_analyzer:搜索时使用的分词器
  • ik_max_word:细粒度分词
  • ik_smart:粗粒度分词

多字段映射 (Multi-fields)

fileName的多字段定义:

"fileName":{"type":"text","fields":{"keyword":{"type":"keyword","ignore_above":256},"raw":{"type":"text","analyzer":"standard"}}}
  • fileName:主字段,使用IK中文分词
  • fileName.keyword:keyword子字段,用于精确匹配、聚合
  • fileName.raw:使用标准分词器的text子字段
  • ignore_above: 256 - 超过256字符的不会被索引

path_analyzer

"filePath":{"type":"text","analyzer":"path_analyzer","fields":{"keyword":{"type":"keyword"}}}
  • path_analyzer:自定义路径分析器,用于文件路径的层次化搜索
  • 可以搜索如/home/user/documents/并匹配子路径

数值类型 float

"fileSize":{"type":"float"}
  • float:单精度浮点数,适合文件大小存储

日期类型

"updateTime":{"type":"date","format":"yyyy-MM-dd HH:mm:ss||epoch_millis"}
  • format:支持多种日期格式
  • yyyy-MM-dd HH:mm:ss:字符串格式
  • epoch_millis:时间戳格式

tags字段设计

"tags":{"type":"keyword","fields":{"text":{"type":"text","analyzer":"ik_smart"}}}
  • tags:keyword类型,用于精确标签匹配
  • tags.text:text类型,用于标签的全文搜索

自定义路径分析器

"analysis":{"analyzer":{"path_analyzer":{"type":"custom","tokenizer":"path_tokenizer"}},"tokenizer":{"path_tokenizer":{"type":"path_hierarchy"}}}
  • path_hierarchy:专门用于路径层次结构的tokenizer
  • 例如/a/b/c会被分词为:/a,/a/b,/a/b/c

资料获取

大家点赞、收藏、关注、评论啦~

精彩专栏推荐订阅:在下方专栏👇🏻

  • 长路-文章目录汇总(算法、后端Java、前端、运维技术导航):博主所有博客导航索引汇总
  • 开源项目Studio-Vue—校园工作室管理系统(含前后台,SpringBoot+Vue):博主个人独立项目,包含详细部署上线视频,已开源
  • 学习与生活-专栏:可以了解博主的学习历程
  • 算法专栏:算法收录

更多博客与资料可查看👇🏻获取联系方式👇🏻,🍅文末获取开发资源及更多资源博客获取🍅

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/29 8:04:51

在大模型班学算法的笔记记录-形态学

形态学操作是OpenCV中处理二值图像的核心手段,常用于目标检测、图像降噪、轮廓提取等场景一、核心流程:从原图到二值化形态学操作的前提是得到干净的二值图像,核心步骤为:灰度图 → 低通滤波 → 二值化。1. 灰度图转换彩色图像需先…

作者头像 李华
网站建设 2026/3/29 13:18:27

通信工程毕业设计本科生开题100例

【单片机毕业设计项目分享系列】 🔥 这里是DD学长,单片机毕业设计及享100例系列的第一篇,目的是分享高质量的毕设作品给大家。 🔥 这两年开始毕业设计和毕业答辩的要求和难度不断提升,传统的单片机项目缺少创新和亮点…

作者头像 李华
网站建设 2026/4/1 11:02:21

LeetCode热题100--55. 跳跃游戏--中等

题目 给你一个非负整数数组 nums ,你最初位于数组的 第一个下标 。数组中的每个元素代表你在该位置可以跳跃的最大长度。 判断你是否能够到达最后一个下标,如果可以,返回 true ;否则,返回 false 。 示例 1&#xff…

作者头像 李华
网站建设 2026/3/31 4:41:16

小白-对Docker容器的基本理解(GPT对话)

1. Namespace vs cgroups:先把两大基石分清你的切入点你想知道 Docker 背后到底靠什么实现“隔离”和“轻量”。核心结论Namespace(命名空间):负责“隔离视图”——让容器进程看起来像在独立系统里运行(看不到外部&…

作者头像 李华
网站建设 2026/3/30 6:11:17

LobeChat与LangChain结合应用:开启复杂AI流程新篇章

LobeChat与LangChain结合应用:开启复杂AI流程新篇章 在今天的企业数字化转型浪潮中,一个越来越清晰的趋势正在浮现:用户不再满足于“能回答问题”的聊天机器人,而是期待一个真正“能办事”的智能助手。想象一下,财务人…

作者头像 李华
网站建设 2026/4/2 18:25:22

基于单片机的节能窗控制系统设计

基于单片机的节能窗控制系统设计 第一章 引言 在全球能源危机日益严峻的背景下,建筑节能成为降低能源消耗的关键领域。窗户作为建筑与外界能量交换的主要通道,其保温隔热性能直接影响建筑能耗。传统窗户依赖人工操作,无法根据环境变化实时调…

作者头像 李华