news 2026/4/18 8:01:26

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/4/17 12:47:45

Dify与Tesseract协同加速实战(识别速度提升90%的机密方案)

第一章:Dify Tesseract 的识别速度Dify Tesseract 是一种结合了 Dify 框架与 Tesseract OCR 引擎的智能文本识别解决方案,其识别速度在多种应用场景中表现出色。通过优化图像预处理流程和并行化任务调度,系统能够在毫秒级时间内完成高精度文本…

作者头像 李华
网站建设 2026/4/16 10:51:52

【Docker Offload任务调度深度解析】:掌握优先级设置的5大核心技巧

第一章:Docker Offload任务优先级设置概述在现代容器化应用部署中,资源调度与任务优先级管理是保障系统稳定性和响应效率的关键环节。Docker Offload机制允许将部分计算或网络处理任务卸载至专用硬件(如GPU、SmartNIC等)&#xff…

作者头像 李华
网站建设 2026/4/18 5:42:37

buuctf Misc(杂项) [SWPU2019]我有一只马里奥

小白解题题目如下下载附件,是一个.exe(无从下手,点一下试试)点一下之后,自动给一个txt打开后是这样的方向明确 NTFS隐写,果断使用NtfsStreamsEditor搜索文件直接打开得到flagflag{ddg_is_cute}

作者头像 李华