[Elasticsearch] ES 的Mapping 设计在实际场景中应用

[Elasticsearch] ES 的Mapping 设计在实际场景中应用背景 项目中有个需求是需要几个字段作为标签,统计各个标签的文档数量,同时支持分词后的全文检索功能。 原有的mapping设计: curl -XPUT http://ip:9200/meta_es_me

[Elasticsearch] ES 的Mapping 设计在实际场景中应用

背景

项目中有个需求是需要几个字段作为标签,统计各个标签的文档数量,同时支持分词后的全文检索功能。

原有的mapping设计:

curl -XPUT http://ip:9200/meta_es_metric_data -d"

{
  "settings": {
    "number_of_shards": 5,
    "number_of_replicas": 0
  },
  "mappings": {
    "meta_metric": {
      "properties": {
        "metricCode": {
          "type": "text",
           "analyzer" : "ik_max_word"
        },
        "metricTechType": {
          "type": "keyword"
        },
        "dataDomainName": {
          "type": "keyword"
        },
        "sceneClassify": {
          "type": "keyword"
        },
        "metricClassify": {
          "type": "keyword"
        }
      }
    }
  }
}"

其中keyword类型就是作为标签统计字段,因为其类型不支持分词检索,检索时必须精确查找,我们尝试把其类型修改成text,text本身就是支持分词索引,但是修改后就报错了:

Fielddata is disabled on text fields by default 

经过查询了解es一个字段类型被设置为text,再进行聚合统计,就会报上面的问题.

那么ES有没有办法对一个字段支持分词检索同时可以进行统计的特性呢?其实就是ES是否可以一个字段定义两种类型: keyword 和 text?

答案是可以的.

ES字段的fields属性

通过fields属性来让当前字段同时具备keyword和text类型

由于我们本身的字段类型是keyword,那我在field 属性中添加一个text,是否就满足需求呢?如:

curl -XPUT http://ip:9200/meta_es_metric_data -d"

{
  "settings": {
    "number_of_shards": 5,
    "number_of_replicas": 0
  },
  "mappings": {
    "meta_metric": {
      "properties": {
        "metricCode": {
          "type": "text",
           "analyzer" : "ik_max_word"
        },
        "metricTechType": {
          "type": "keyword"
          fields": {
                "raw": { 
                   "type":  "text"
             }
          }
        }
      }
    }
  }
}"

当用match 搜索metricTechType.raw, 分词搜索是不行的。

之所以想这样做是因为ES支持新增字段、更新字段,但是不支持字段类型的修改

这条方法走不通,就比较复杂了,因为考虑修改字段类型,我们只能重建mapping, 同时涉及历史数据的加载处理。

具体步骤

1.重建索引,因es不支持修改字段类型

curl -XPUT http://ip:9200/meta_es_metric_data_new -d"

{
  "settings": {
    "number_of_shards": 5,
    "number_of_replicas": 0
  },
  "mappings": {
    "meta_metric": {
      "properties": {
        "metricCode": {
          "type": "text",
           "analyzer" : "ik_max_word"
        },
    
        "metricTechType": {
          "type": "text",
           "fields": {
                    "raw": { 
                      "type":  "keyword"
             }
          }
        },

        "dataDomainName": {
          "type": "text",
           "fields": {
                    "raw": { 
                   "type":  "keyword"
             }
          }
        },

        "sceneClassify": {
          "type": "text",
          "fields": {
                    "raw": { 
                   "type":  "keyword"
             }
          }
        },

        "metricClassify": {
          "type": "text",
          "fields": {
                    "raw": { 
                    "type":  "keyword"
             }
          }
        }
      }
    }
  }
}"

2.查看索引映射

curl -XGET  "http://ip:9200/meta_es_metric_data_new/_mapping"

3.将数据加载到新的索引上(老索引的数据还是在的)

curl -XPOST http://ip:9200/_reindex -d"
{
    "source":{
       "index": "meta_es_metric_data"
    },

    "dest": {
        "index": "meta_es_metric_data_new"
    }
    
}"

4.查看老索引数据:


curl -XGET "http://ip:9200/meta_es_metric_data/_search?pretty" -H "Content-Type: application/json" -d"
{
  "query": {
    "match": {
      "dataDomainName": "用户"
    }
  }
}
"

5.删除原索引,给新索引创建别名(为了代码不动)

curl -XDELETE http://ip:9200/meta_es_metric_data

curl -XPOST http://ip:9200/_aliases -d"
{
    "actions":[
        {
           "add": {
                "index": "meta_es_metric_data_new",
                "alias": "meta_es_metric_data"
           }

        }
    ]
    
}"

6.测试字段是否支持全文检索及聚合

curl -XGET "http://ip:9200/meta_es_metric_data_new/_search?pretty" -H "Content-Type: application/json" -d"
{
  "query": {
    "match": {
      "dataDomainName": "用户"
    }
  },
  "sort": {
    "dataDomainName.raw": "asc" 
  },
  "aggs": {
    "Cities": {
      "terms": {
        "field": "dataDomainName.raw"
      }
    }
  }
}
"

总结

本文主要讲解如何让一个字段支持不同方式索引,利用Fields属性. 同时如何对历史存量数据进行处理. keyword类型支持es精确查找以及聚合排序,text支持全文检索,但是不能进行聚合、排序.

参考

  1. https://doc.codingdict.com/elasticsearch/330/

  2. https://cloud.tencent.com/developer/article/1555004

本文作者: chaplinthink, 关注领域:大数据、基础架构、系统设计, 一个热爱学习、分享的大数据工程师

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

(0)
上一篇 2023-05-02
下一篇 2023-05-02

相关推荐

  • 使用Python if语句多个条件判断

    使用Python if语句多个条件判断Python作为广泛应用的编程语言之一,其if语句是编程中非常重要的一部分,在判断特定条件下的程序流程上有着非常重要的作用。当需要在多个条件中进行判断时,Python if语句的多个条件判断就成为了解决问题的关键。

    2024-04-15
    83
  • Python类的定义和使用

    Python类的定义和使用
    Python中的类是一种自定义数据类型,允许我们定义自己的数据结构,包括数据属性(成员变量)和方法(成员函数),并支持面向对象编程中的封装、继承和多态等特性。类是一种模板,可以通过实例化获得对象,每个对象具有相同的属性和方法,但这些属性可能具有不同的值。

    2023-12-26
    123
  • centos7 oracle12c安装_centos7安装oracle数据库

    centos7 oracle12c安装_centos7安装oracle数据库CentOS7安装Oracle12c图文详解 海淀农民 2018-10-29 11:27:25 6462 收藏 9 分类专栏: linux Oracle 环境: CentOS7@VMware12,分…

    2023-03-20
    158
  • Python arange函数详解

    Python arange函数详解a href=”https://beian.miit.gov.cn/”苏ICP备2023018380号-1/a Copyright www.python100.com .Some Rights Reserved.

    2024-05-06
    92
  • 5G拍照手机如何选择?数码老司机来聊下

    5G拍照手机如何选择?数码老司机来聊下     最近在家无聊,闲来无事翻了翻网上关于5G拍照手机的信息,发现很多朋友对于如何选择5G拍照手机非常困惑,作为一个从事手机行业6年的老师傅,今天就在这里和大家分享一下如何选择5G拍照手机!  …

    2023-02-23
    147
  • sqlserver表连接方式_sql server数据表的关联

    sqlserver表连接方式_sql server数据表的关联数据库操作中,我们需要的结果可能在两张表甚至多张表中,这时候就需要表连接操作,多表查询中的各个表之间的字段会存在连接,比如主外键关联,可以使用主外键来关联每张表。表连接方式有以下几种: JOIN: 如

    2022-12-25
    163
  • Docker-compose常用软件部署(mysql、redis、rabbitmq)

    Docker-compose常用软件部署(mysql、redis、rabbitmq) Docker-compose常用软件部署(mysql、redis、rabbitmq) 废话不多说,下面就直接给出部署文件已经启动脚本,这个会持续更新。以下的部署方式均是单例部署。高可用或者其…

    2023-03-23
    137
  • 《阿里巴巴Java开发手册》码出高效详解(一)- 为什么要学习阿里编码手册「建议收藏」

    《阿里巴巴Java开发手册》码出高效详解(一)- 为什么要学习阿里编码手册「建议收藏」《Java 开发手册》(以下简称《手册》)是每个 Java 工程师人手必备的一本参考指南。该手册包括 编程规约、异常日志、单元测试、安全规约、MySQL 数据库、工程结构、设计规约 7 个部分 ,涵盖

    2023-01-25
    137

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注