首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为什么我天真的Elasticsearch更新经常因文档版本冲突而失败?

为什么我天真的Elasticsearch更新经常因文档版本冲突而失败?
EN

Stack Overflow用户
提问于 2014-03-19 13:30:03
回答 1查看 379关注 0票数 1

我使用的是版本0.9,我有一种非常天真的方法来更新文档,它本质上做了一个比较和交换:

(只显示相关代码)

代码语言:javascript
复制
    for (int i = 0; i < MAX_RETRY; i++) {
        GetResponse get = client.prepareGet().execute().actionGet();
        // Assume document already exists
         try {
              client
                .prepareIndex()
                .setId(id)
                .setSource(newDoc)
                .setVersion(get.getVersion())
                .execute()
                .actionGet();
                // Successfully updated
         } catch (VersionConflictEngineException e) {
             continue; //retry
         }
         throw UpdateFailedException();
    } 

这些代码适用于大多数更新,但也比我预期的版本冲突更频繁地失败。奇怪的是,当服务器文档失败时,它总是看起来是+1预期的版本。有什么明显的事我错过了吗?

我知道Elasticsearch有一个正确的更新功能,但我不能使用这个ATM。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-08-24 23:43:16

结果发现,由于一个bug,我经常在合法地更新文档。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22507455

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档