当粉丝关注公众号,我们会把粉丝数据先存入mysql,然后同步到elasticsearch;开发中遇到更新elasticsearch文档不成功的问题,查看log,发现报404错误,错误type为document_missing_exception。去elasticsearch官网查看了Update API文档,发现了可以解决此问题的两个适用的参数,一个是upsert,另一个是doc_as_upsert。
upsert,这个参数主要用于如果文档尚不存在,upsert元素的内容将作为新的文档插入。如果文档存在,则将执行script。这个参数适用于将upsert元素的内容更新或添加到文档中,与script搭配使用。
For Example:
curl -X POST "localhost:9200/test/_doc/1/_update"
{
"script" : {
"source": "ctx._source.follows_count+= params.count",
"params" : {
"count" : 1
}
},
"upsert" : {
"follows_count" : 1
}
}
如果文档存在,执行script,该文档字段follows_count 加1;如果文档不存在,插入新的文档,内容为follows_count:1。
doc_as_upsert,这个参数主要用于如果文档不存在,将doc中的内容插入到文档中。
curl -X POST "localhost:9200/test/_doc/1/_update"
{
"doc" : {
"openid": "oTyBt1tqDf8nI4ntMk6GPgaPaDWg",
"country": "中国",
"unid": "",
"city": "静安",
"sex": 1,
"follows_count": 23,
"subscribe_time": 1552647009,
"province": "上海",
"headimgurl": "http://thirdwx.qlogo.cn/mmopen/GxCCWSMYiasMKwAwjoG07xTYbbkAMql96MfoOibbbrLe1Cznrfk32ZF1oBWiaf9zqz9Bb8ibOjZ9eTTylYRpXY0Ky41KzdfgdReT/132",
"nickname": "lz",
},
"doc_as_upsert" : true
}
对比发现doc_as_upsert 更适用于解决我的问题。