千家信息网

怎样解决Elasticsearch type 不一致导致写入数据失败的问题

发表于:2025-12-03 作者:千家信息网编辑
千家信息网最后更新 2025年12月03日,这期内容当中小编将会给大家带来有关怎样解决Elasticsearch type 不一致导致写入数据失败的问题,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。在 Ela
千家信息网最后更新 2025年12月03日怎样解决Elasticsearch type 不一致导致写入数据失败的问题

这期内容当中小编将会给大家带来有关怎样解决Elasticsearch type 不一致导致写入数据失败的问题,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

在 Elasticsearch 7.x 以前的版本中,当ES Client写数据的时候报了如下错误:

2020-03-13 10:00:41.076 ERROR 9 --- [Report ES Thread 0] .g.c.c.AbstractElasticsearchReportClient : item: 2634ef87-ec48-4d38-899f-508ba8b69b9c, errorReason: Rejecting mapping update to [journal_test] as the final mapping would have more than 1 type: [default, doc]

意思就是说你写入的数据的中的type 与你创建索引时指定type不一致。比如我创建时 "_type":"_doc",而写入时为 "_type":"default"。因此,有两种办法,要么修改写入数据时的 type ,要么修改当前索引的 type 。

不过在最新的 7.x 没有该问题了,因为 官方已经把 type 功能移除了。

考虑到更改写入时候的 type 就得重启应用,会影响用户使用。所以这里采用修改当前索引的方法。

提供一种最简单的解决思路:通过 Elasticsearch 的 reindex 功能将当前索引 journal_test 备份至 journal_test_back 索引并删除 journal_test,让 ES 根据写入数据时自动生成 type 为 default 的索引。随后将备份数据导出到文件,修改文件中 type 为 default。再写入原来新的 journal_test_2 索引。

将 journal_test_2 索引数据备份至 journal_test_2_bak索引:

curl -X POST "localhost:9200/_reindex?pretty" -H 'Content-Type: application/json' -d'
{
"source": {
"index": "journal_test"
},
"dest": {
"index": "journal_test_back"
}
}
'

删除 journal_test 索引,让你的应用再次写入数据时 ES 自己创建索引:

curl -X DELETE "http://localhost:9200/journal_test"

journal_test_back 数据导出到 my_index_mapping.json 文件中

这里借助工具:https://github.com/taskrabbit/elasticsearch-dump,将 备份数据导出到我本地 Desktop 目录下:

docker run --rm -ti -v ~/Desktop:/tmp taskrabbit/elasticsearch-dump \
--input=http://localhost:9200/journal_test_back \
--output=/tmp/my_index_mapping.json \
--type=data

编辑 my_index_mapping.json 文件,将 type 修改为 default。注意,为了不影响原来的备份数据,我将修改后的数据写入到新的文件(my_index_mapping_default.json)中:

cat my_index_mapping.json| sed s/\"_type\":\"doc\"/\"_type\":\"default\"/ > my_index_mapping_default.json

最后一步,将正确的数据导入正确的 journal_test 索引中:

docker run --rm -ti -v ~/Desktop:/tmp taskrabbit/elasticsearch-dump \
--output=http://localhost:9200/journal_test \ # 注意索引名
--input=/tmp/my_index_mapping_default.json \ #注意这里使用的文件
--type=data

上述就是小编为大家分享的怎样解决Elasticsearch type 不一致导致写入数据失败的问题了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注行业资讯频道。

数据 索引 文件 备份 一致 问题 内容 功能 就是 时候 要么 分析 应用 影响 专业 中小 内容丰富 再次 办法 官方 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 什么是软件什么是软件开发 微微一笑倾城糜烂了服务器 比特币数据库安全吗 北京5g服务器机柜厂云空间 江津区一站式网络技术内容 四年级上册美术网络安全课后反思 软件开发者能看到手机ip吗 教育专区服务器是什么意思 数据库技术画图 软件开发文档封面文案 mysql 缓存数据库 拼多多用什么软件看数据库 数据库 重新排序id 信息和网络安全的重要性 数据库把两个表拼接成一列 银行网络安全事例 湖北居家智慧养老软件开发 启步上海网络技术有限公司 网络安全需要研究生学历吗 查找手机服务器异常怎么回事 兴业数金和中信银行软件开发岗位 双鹿电池的软件开发 数据库标签初始化 云数据库服务化 dba 数据库删除表里的数据 软件开发的薪酬待遇 拼多多用什么软件看数据库 服务器上缺失了组件服务 iss服务器怎么配 网络安全预防诈骗主题班会
0