创建索引以后,索引的设定和很多固定配置将不能改变,如果需要改变数据结构就需要重建索引
Elasticsearch v6.3.1以后支持Reindex API重建索引
已有索引库book和book_new
book为源索引,book_new为目标索引
整个过程为book重建索引到book_new
如果不手动创建book_new的mapping信息,elasticsearch将自动映射数据类型
POST _reindex
{
"source": {
"index": "book"
},
"dest": {
"index": "book_new",
"version_type": "internal"
}
}
参数配置
version_type
在修改数据的时候es会修改数据的version
version_type会对迁移的_version做出处理
- internal:直接拷贝文档到目标索引,对相同的type、文档ID直接进行覆盖,默认值
- external:迁移文档到目标索引时,保留version信息,对目标索引中不存在的文档进行创建,已 存在的文档按version进行更新,遵循乐观锁机制。
op_type
op_type设置为create,那么源索引库的文档迁移到目标库的时候,只会迁移源库有id而目标库没有的id的文档,已存在的会提示错误信息
POST _reindex
{
"conflicts": "proceed",
"source": {
"index": "book"
},
"dest": {
"index": "book_new",
"op_type": "create"
}
}
如果加上"conflicts": “proceed”,则不提示错误信息
query
reindex api支持数据过滤、数据排序、size设置、_source选择等
迁移price大于10小于400的
POST _reindex
{
"conflicts": "proceed",
"source": {
"index": "book",
"query": {
"range": {
"price": {
"gte": 10,
"lte": 400
}
}
}
},
"dest": {
"index": "book_new",
"op_type": "create"
}
}