使用esm数据迁移报错“reason“:“Action/metadata line [1] contains an unknown parameter [_routing]

  • Post author:
  • Post category:其他


问题描述:使用esm导出本环境的索引,然后删除对应的索引,测试是否能够导入回去。

在es7.X版本之前的环境中,导出的数据是可以导回去的。但是在es7.X以及之后的环境中使用同个版本的esm导出的数据,就不能再导回去了。完整报错如下:

[v0.go:79,Bulk] server error: {“error”:{“root_cause”:[{“type”:”illegal_argument_exception”,”reason”:”Action/metadata line [1] contains an unknown parameter [_routing]”}],”type”:”illegal_argument_exception”,”reason”:”Action/metadata line [1] contains an unknown parameter [_routing]”},”status”:400}

查看了es的特性,添加了参数– rename的参数:

to migrate version 7.x and you may need to rename

_type

to

_doc:

./esm -s http://localhost:9201 -x "source" -y "target"  -d https://localhost:9200 --rename="_type:type,_routing:routing"  -u"_doc"

执行还是报错,问题没有解决。原来问题出在es7.X的批量写入时,路由字段_routing改成了routing,没有下划线。

最后将esm升级到最新的版本才解决。

源码地址:

https://github.com/medcl/esm/

之前使用的版本不太记得是哪个版本了,所以将esm升级到目前最新的版本之后,在执行就没有报错了,可以成功执行。

如果你遇到和我一样的问题,那么可以试一试这个方法解决。



版权声明:本文为wyz0516071128原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。