美文网首页ElasticSearch入门玩转大数据大数据
十九、Elasticsearch如何基于_version进行乐观

十九、Elasticsearch如何基于_version进行乐观

作者: 编程界的小学生 | 来源:发表于2017-07-05 13:49 被阅读108次

    1、_version元数据

    PUT /test_index/test_type/6
    {
      "test_field" : "test test"  
    }
    

    返回结果

    {
      "_index": "test_index",
      "_type": "test_type",
      "_id": "6",
      "_version": 1,
      "result": "created",
      "_shards": {
        "total": 5,
        "successful": 1,
        "failed": 0
      },
      "created": true
    }
    

    第一次创建一个document的时候,他的_version内部版本号就是1;以后,每次对这个document执行修改或者删除操作,都会对这个_version版本号自动加1;哪怕是删除也会对这条数据的版本号加1。
    DELETE /test_index/test_type/6

    返回结果

    {
      "found": true,
      "_index": "test_index",
      "_type": "test_type",
      "_id": "6",
      "_version": 2,
      "result": "deleted",
      "_shards": {
        "total": 5,
        "successful": 1,
        "failed": 0
      }
    }
    

    再次PUT

    PUT /test_index/test_type/6
    {
      "test_field" : "test test"  
    }
    

    返回结果:

    {
      "_index": "test_index",
      "_type": "test_type",
      "_id": "1",
      "_version": 3,
      "result": "updated",
      "_shards": {
        "total": 5,
        "successful": 1,
        "failed": 0
      },
      "created": false
    }
    

    发现版本号变成了3

    我们发现,再删除一个document之后,可以从一个侧面证明,他不是立即物理删除的,因为他的一些版本号等信息还是保留着的。先删除一条document,再重新创建这条document,其实会在delete version基础之上,再把version号加1

    Paste_Image.png

    若有兴趣,欢迎来加入群,【Java初学者学习交流群】:458430385,此群有Java开发人员、UI设计人员和前端工程师。有问必答,共同探讨学习,一起进步!
    欢迎关注我的微信公众号【Java码农社区】,会定时推送各种干货:


    qrcode_for_gh_577b64e73701_258.jpg

    相关文章

      网友评论

      • 要没时间了_3c48:先删除这条doc,再新建这条doc,它是根据什么来判定是同一条doc,是_id吗?

      本文标题:十九、Elasticsearch如何基于_version进行乐观

      本文链接:https://www.haomeiwen.com/subject/hucqhxtx.html