ElasticSearch reindex创建新索引并指定路由

借助ES reindex,将源索引数据同步到新索引中,并在新索引中将指定字段作为路由routing

源索引信息

1.源索引创建mapping结构

PUT /regular_address_test
{
  "mappings" : {
      "properties" : {
        "_class" : {
          "type" : "keyword",
          "index" : false,
          "doc_values" : false
        },
        "address" : {
          "type" : "text",
          "fields" : {
            "accurate" : {
              "type" : "keyword"
            }
          },
          "analyzer" : "ik_max_word"
        },
        "branchCode" : {
          "type" : "keyword"
        },
        "cityName" : {
          "type" : "keyword"
        },
        "companyCode" : {
          "type" : "keyword"
        },
        "countyName" : {
          "type" : "keyword"
        },
        "createBy" : {
          "type" : "keyword"
        },
        "createTime" : {
          "type" : "date",
          "format" : "yyyy-MM-dd HH:mm:ss"
        },
        "distributionCode" : {
          "type" : "keyword"
        },
        "id" : {
          "type" : "text",
          "fields" : {
            "keyword" : {
              "type" : "keyword",
              "ignore_above" : 256
            }
          }
        },
        "mdCodeGuiJi" : {
          "type" : "keyword"
        },
        "mdCodeOther" : {
          "type" : "keyword"
        },
        "mdCodeYiZhan" : {
          "type" : "keyword"
        },
        "provinceName" : {
          "type" : "keyword"
        },
        "sendCode" : {
          "type" : "keyword"
        },
        "sendTime" : {
          "type" : "date",
          "format" : "yyyy-MM-dd HH:mm:ss"
        },
        "trackingNoLatest" : {
          "type" : "keyword"
        },
        "updateBy" : {
          "type" : "keyword"
        },
        "updateTime" : {
          "type" : "date",
          "format" : "yyyy-MM-dd HH:mm:ss"
        }
      }
    },
    
    "settings" : {
        "refresh_interval" : "120s",
        "number_of_shards" : 6,
        "number_of_replicas" : "0"
      
    }
}

2.源索引数据写入时是没有设置路由的

{
  "_index" : "regular_address",
  "_type" : "_doc",
  "_id" : "28ce46ba1665f73f4fca6722e3bdedaa",
  "_version" : 1,
  "_seq_no" : 420109,
  "_primary_term" : 1,
  "found" : true,
  "_source" : {
    "_class" : "com.yd.addr.regular.core.entity.RegularAddress",
    "id" : "28ce46ba1665f73f4fca6722e3bdedaa",
    "address" : "安徽省合肥市肥西县桃花工业园丹霞路281号南城创谷后侧院内联强运筹三楼",
    "provinceName" : "安徽省",
    "cityName" : "合肥市",
    "countyName" : "肥西县",
    "distributionCode" : "230001",
    "companyCode" : "230017",
    "branchCode" : "231081",
    "sendCode" : "J4",
    "mdCodeGuiJi" : "",
    "mdCodeYiZhan" : "",
    "mdCodeOther" : "MD300003874223",
    "trackingNoLatest" : "462247184479337",
    "sendTime" : "2022-02-20 13:50:32",
    "createBy" : "system",
    "createTime" : "2022-03-10 14:43:08",
    "updateBy" : "system",
    "updateTime" : "2022-03-10 14:43:08"
  }
}

目标索引信息

1.目标索引创建
相比源索引的创建配置,新增了routing.required=true。在setting中,新增routing_partition_size=4,去减少自定义路由导致数据倾斜带来的影响

PUT /regular_address_test
{
  "mappings" : {
    "_routing": {
        "required": true
      }, 
      "properties" : {
        "_class" : {
          "type" : "keyword",
          "index" : false,
          "doc_values" : false
        },
        "address" : {
          "type" : "text",
          "fields" : {
            "accurate" : {
              "type" : "keyword"
            }
          },
          "analyzer" : "ik_max_word"
        },
        "branchCode" : {
          "type" : "keyword"
        },
        "cityName" : {
          "type" : "keyword"
        },
        "companyCode" : {
          "type" : "keyword"
        },
        "countyName" : {
          "type" : "keyword"
        },
        "createBy" : {
          "type" : "keyword"
        },
        "createTime" : {
          "type" : "date",
          "format" : "yyyy-MM-dd HH:mm:ss"
        },
        "distributionCode" : {
          "type" : "keyword"
        },
        "id" : {
          "type" : "text",
          "fields" : {
            "keyword" : {
              "type" : "keyword",
              "ignore_above" : 256
            }
          }
        },
        "mdCodeGuiJi" : {
          "type" : "keyword"
        },
        "mdCodeOther" : {
          "type" : "keyword"
        },
        "mdCodeYiZhan" : {
          "type" : "keyword"
        },
        "provinceName" : {
          "type" : "keyword"
        },
        "sendCode" : {
          "type" : "keyword"
        },
        "sendTime" : {
          "type" : "date",
          "format" : "yyyy-MM-dd HH:mm:ss"
        },
        "trackingNoLatest" : {
          "type" : "keyword"
        },
        "updateBy" : {
          "type" : "keyword"
        },
        "updateTime" : {
          "type" : "date",
          "format" : "yyyy-MM-dd HH:mm:ss"
        }
      }
    },
    
    "settings" : {
        "routing_partition_size": 4,
        "refresh_interval" : "120s",
        "number_of_shards" : 8,
        "number_of_replicas" : "0"
      
    }
}

_reindex导入数据并配置路由

这里将字段branchCode作为路由配置

POST _reindex
{
  "source": {
    "index": "regular_address"
  },
  "dest": {
    "index": "regular_address_test",
    "routing": "=ctx._routing"
  },
  "script": {
    "source": "ctx._routing = ctx._source.branchCode"
  }
}

效果展示

目标索引数据会按路由进行分片
_routing字段是指定的字段值
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值