索引映射(mappings)管理及配置管理

elasticsearch中的文档等价于java中的对象,那么在java对象中有字段(比如string、int、long等),同理在elasticsearch索引中的具体字段也是有类型的。

如果没有指定字段类型,elasticsearch会默认指定。但最好是使用mapping的映射管理,提前指定字段的类型,防止后续的程序问题;

PUT school
{
  "mappings": {
    "logs" : {
      "properties": {"messages" : {"type": "text"}}
    }
  }

获取映射字段

语法:

GET /{index}/_mapping/{type}/field/{field}

GET /school/_mapping/logs/field/number

索引库配置管理

索引库配置

所谓的settings就是用来修改索引分片和副本数的;

比如有的重要索引,副本数很少甚至没有副本,那么我们可以通过setting来添加副本数

DELETE document
PUT document
{
  "mappings": {
    "article" : {
      "properties":
      {
        "title" : {"type": "text"} , 
        "author" : {"type": "text"} , 
        "titleScore" : {"type": "double"} 
        
      }
    }
  }
}
GET /document/_settings

为了提高容错性,我们可以把副本数改成2:

PUT /document/_settings
{
  "number_of_replicas": 2
}

副本可以改,分片不能改

零停机重新索引数据

对于文档的操作,偶尔会遇到这种问题:

某一个字段的类型不符合后期的业务了,但是当前的索引已经创建了,我们知道es在字段的mapping建立后就不可再次修改mapping的值。

1 新建索引库articles1,并添加数据

DELETE articles1
PUT articles1
{  
    "settings":{  
         "number_of_shards":3,  
         "number_of_replicas":1  
    },  
    "mappings":{  
         "article":{  
             "dynamic":"strict",  
             "properties":{  
                 "id":{"type": "text", "store": true},  
                 "title":{"type": "text","store": true}, 
                 "readCounts":{"type": "integer","store": true},  
                 "times": {"type": "text", "index": false}
             }  
         }  
    }  
}


PUT articles1/article/1
{
  "id" : "1",
  "title" : "世界1",
  "readCounts" : 2 , 
  "times" : "2018-05-01"
}

get articles1/article/1

2 新建索引库articles2

DELETE articles2
PUT articles2
{  
    "settings":{  
         "number_of_shards":5,  
         "number_of_replicas":1  
    },  
    "mappings":{  
         "article":{  
             "dynamic":"strict",  
             "properties":{  
                 "id":{"type": "text", "store": true},  
                 "title":{"type": "text","store": true}, 
                 "readCounts":{"type": "integer","store": true},  
                 "times": {"type": "date", "index": false}
             }  
         }  
    }  
}  
}


GET articles2/article/1

3 拷贝数据并验证

POST _reindex
{
  "source": {
    "index": "articles1"
  },
  "dest": {
    "index": "articles2"
  }
}

GET articles2/article/1
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
第六章“映射”是指在Elasticsearch中定义和配置索引的字段映射规则。在Elasticsearch中,索引中的每个字段都有自己的数据类型和属性,通过映射可以告诉Elasticsearch如何解析和处理这些字段的数据。 映射的主要作用是定义字段的数据类型,例如字符串、数字、日期等,以及字段的索引方式,例如是否进行全文索引、是否进行排序等。通过映射设置,我们可以在索引创建之前预先定义字段的数据类型,避免了数据类型的混乱和不一致。 在Elasticsearch中,映射可以通过两种方式进行定义:动态映射和静态映射。 动态映射是指当我们索引一条新的文档时,Elasticsearch会自动识别并根据文档中的字段对其进行动态映射。通过动态映射,我们可以很方便地处理不同类型的文档,并且无需手动定义每个字段的映射规则。 静态映射则是指我们手动定义和配置字段的映射规则。通过静态映射,我们可以更加精确地控制字段的数据类型、索引方式以及其他属性。静态映射可以在索引创建之前进行定义,也可以通过修改已有的映射进行更新。 在使用映射时,我们需要注意字段的数据类型选择是否合适,避免过度索引导致性能下降,还需要注意字段的分析配置是否符合需求,以便在搜索时获得准确的结果。 总的来说,映射是Elasticsearch中重要的一部分,通过定义和配置字段的映射规则,我们可以更好地管理和利用数据,提高搜索的准确性和效率。在实际应用中,我们需要根据具体的需求和数据特点,灵活地选择和配置映射规则。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值