Elasticsearch 添加失败 MapperParsingException[object mapping for [] tried to parse field [null] as object, but found a concrete value

soゝso 2016-08-22 18:52:41 3554
分享到:

昨晚在做一个 Elasticsearch   Demo   的时候,发现了这个错误,纠结了一小会,我的 Demo  是爬虫随便爬取了一些网站的信息,然后通过 Elasticsearch  去存储,结果发现其中一个字段,Mapping定义的类型是objcet,因为是个Array,而 Mapping  又定义不了Array ,所以定义了一个object 类型。结果创建 Mapping  成功了,但是添加数据失败了。

更多的Elasticsearch  ,请点击这里: Elasticsearch教程  ,本博客主要针对2.0以上的 Elasticsearch  版本相关使用,以Java API为主,适用于初级 Elasticsearch  使用者参考。如果有问题可以加群一起讨论。

下面关于:

failure in bulk execution:

Elasticsearch 添加失败 MapperParsingException[object mapping for [] tried to parse field [null] as object, but found a concrete value

错误的排查的过程和结果。

我的 Mapping 

{
    "mappings": {
        "site_type1": {
            "_ttl": {
                "enabled": false
            },
            "properties": {
                "server_address": {
                    "index": "not_analyzed",
                    "type": "string"
                },
                "baidu_suoyin": {
                    "type": "long"
                },
                "baidu_keys": {
                    "type": "long"
                },
                "beian_title": {
                    "index": "not_analyzed",
                    "type": "string"
                },
                "domain_server": {
                    "index": "not_analyzed",
                    "type": "string"
                },
                "domain_service": {
                    "index": "not_analyzed",
                    "type": "string"
                },
                "beian_index": {
                    "index": "not_analyzed",
                    "type": "string"
                },
                "br": {
                    "type": "long"
                },
                "city": {
                    "type": "object"
                },
                "qihu_shoulu": {
                    "type": "long"
                },
                "title": {
                    "type": "string"
                },
                "baidu_fanlian": {
                    "type": "long"
                },
                "baidu_pv": {
                    "type": "long"
                },
                "beian_type": {
                    "index": "not_analyzed",
                    "type": "string"
                },
                "server_ip": {
                    "type": "string"
                },
                "description": {
                    "type": "string"
                },
                "province": {
                    "type": "object"
                },
                "domain": {
                    "index": "not_analyzed",
                    "type": "string"
                },
                "sougou_fanlian": {
                    "type": "long"
                },
                "beian_number_no": {
                    "index": "not_analyzed",
                    "type": "string"
                },
                "beian_number": {
                    "index": "not_analyzed",
                    "type": "string"
                },
                "tags": {
                    "type": "object"
                },
                "qihu_fanlian": {
                    "type": "long"
                },
                "keywords": {
                    "type": "string"
                },
                "beian_name": {
                    "index": "not_analyzed",
                    "type": "string"
                },
                "baidu_shoulu": {
                    "type": "long"
                },
                "sr": {
                    "type": "long"
                },
                "alexa_pv": {
                    "type": "long"
                },
                "image": {
                    "type": "object"
                },
                "domain_begin_date": {
                    "index": "not_analyzed",
                    "type": "string"
                },
                "baidu_yue_shoulu": {
                    "type": "long"
                },
                "sougou_shoulu": {
                    "type": "long"
                },
                "url": {
                    "index": "not_analyzed",
                    "type": "string"
                },
                "server_type": {
                    "index": "not_analyzed",
                    "type": "string"
                },
                "server_timeout": {
                    "type": "long"
                },
                "google_fanlian": {
                    "type": "long"
                },
                "google_shoulu": {
                    "type": "long"
                },
                "update_time": {
                    "format": "strict_date_optional_time||epoch_millis",
                    "type": "date"
                },
                "domain_end_date": {
                    "index": "not_analyzed",
                    "type": "string"
                },
                "alexa_top": {
                    "type": "long"
                },
                "site_type": {
                    "type": "object"
                },
                "server_html_type": {
                    "index": "not_analyzed",
                    "type": "string"
                },
                "pr": {
                    "type": "long"
                },
                "baidu_zhou_shoulu": {
                    "type": "long"
                }
            }
        }
    }
}

添加数据的时候报错:

failure in bulk execution:
[0]: index [site_index1], type [site_type1], id [http://www.sojson.com], message [MapperParsingException[object mapping for [image] tried to parse field [null] as object, but found a concrete value]]

已经说的很清楚了,就是Mapping 和存储的数据类型对不上。

"image": {
	"type": "object"
}

我开始排查存储的值有没有null 值,发现没有,都是有值了。

其实当报这样的错。有一个最简单的排查方式,就是不创建mapping ,然后直接创建索引,你看看自适应的mapping ,这个field 是什么类型。那么你创建就是什么类型。

我用自适应类型,发现这个数组的是string 类型,那么我就把它定义为string ,就解决错误了。


关于作者
目前就职于国内某电商平台公司打杂。。
相关文章
Elasticsearch教程(五) elasticsearch Mapping的创建
Elasticsearch教程,Elasticsearch Java API创建Mapping,指定分词器
Elasticsearch教程,Elasticsearch安全篇,通过Nginx http basic 限制访问
Elasticsearch权威指南-中文.pdf,Elasticsearch 中文文档下载
Elasticsearch 插件(备忘录)
Elasticsearch教程(二),IK分词器安装
Elasticsearch 随机返回数据 API
Elasticsearch教程,Elasticsearch 设置近义词搜索,IK分词器实现同义词搜索
Elasticsearch教程(六) elasticsearch Client创建
Elasticsearch教程 ,Elasticsearch count 查询,Elasticsearch 查询是否存在
最新文章
免费天气API,全国天气 JSON API接口,可以获取五天的天气预报 38952
JS解密,JavaScript 解密,任何JS加密都能100%解密,以及JS 加密讲解 72
阿里云DNS 解析讲解,SEO配置搜索引擎线路解析 43
百度秒收录教程,怎么做到百度秒收入你的页面,SEO 教程 97
CDN 请求返回 connection reset by peer,被拦截请求解决方案 35
Google AdSense 申请技巧,谷歌广告申请通不过教程 67
Mac 安装 JMeter,JMeter 下载,JMeter Http 压力测试【图解】 49
支付宝吱口令自动复制脚本,自动复制 JavaScript 代码介绍 887
谈谈这次对 SOJSON 的改版 149
Java 计算2个时间相差多少年,多少个月,多少天的几种方式 492
最热文章
免费天气API,全国天气 JSON API接口,可以获取五天的天气预报 38952
Elasticsearch教程(四) elasticsearch head 插件安装和使用 109045
Elasticsearch教程(六) elasticsearch Client创建 73282
Elasticsearch教程(八) elasticsearch delete 删除数据(Java) 70746
Elasticsearch教程(二),IK分词器安装 67471
Elasticsearch教程(三),IK分词器安装 (极速版) 54078
Elasticsearch教程(五) elasticsearch Mapping的创建 51579
Elasticsearch教程(一),全程直播(小白级别) 51306
Elasticsearch教程(七) elasticsearch Insert 插入数据(Java) 47753
Elasticsearch权威指南-中文.pdf,Elasticsearch 中文文档下载 40919

骚码加入我们 / 千人QQ群:259217951

入群需要5元,如果没有QQ钱包,可以先Alipay、微信,赞助然后加群主拉进。

二维码生成 来自 >> 二维码生成器

支付扫码

所有赞助/开支都讲公开明细,用于网站维护:赞助名单查看

正在加载... ...