Elasticsearch 修改mapping字段类型
背景
最近在工作中发现查询功能有BUG,记录一下问题。经过分析排查发现是Elasticsearch分词器原因导致的问题。例如:name字段存储:zhangsan,zhangsan_xx ,ES的分词器会将 zhangsan_xx 分为 zhangsan 和 xx。根据name查询zhangsan时就会出现 zhangsan_xx 的相关信息。
修改方案
因es不支持修改,所以只能新建一个索引,将原索引内容复制到新建的索引内,删除原来的索引,在新建同名索引,将数据复制过去
. 创建一个中间索引
. 向中间索引备份源索引的数据(mapping)
. 查询确认数据是否copy过去
. 删除有问题的索引
. 重新创建同名的索引(★字段类型修改正确★)
. 从中间索引还原到源索引的数据
. 删除中间索引
操作步骤
1.创建一个中间索引
查看索引映射
GET /gb/_mapping
"name": {
"type": "string",
"analyzer": "ik_max_word"
},
name 字段为 string 类型
创建索引
PUT gb1/ {_mapping}
{
"mappings": {
"mgmt-chl-index": {
"properties": {
"channelManagerId": {
"type": "string",
"index": "not_analyzed"
}
}
}
},
"settings": {
"index": {
"number_of_shards": "2",
"number_of_replicas": "1"
}
}
}
2. 向中间索引备份源索引的数据
copy索引内容
POST _reindex
{
"source": {
"index": "gb"
},
"dest": {
"index": "gb1"
}
}
3.查询确认数据是否copy过去
查看索引内容数量是否一致
4.删除有问题的索引
删除有问题的索引
DELETE mgmt-chl-index
5.重新创建同名的索引(★字段类型修改正确★)
#创建索引
PUT gb/ {_mapping}
6. 从中间索引还原到源索引的数据
重建索引
POST _reindex
{
"source": {
"index": "gb1"
},
"dest": {
"index": "gb"
}
}
7. 删除中间索引
DELETE gb1