11,图解Elasticsearch内部如何基于_version进行乐观锁并发控制

1、图解Elasticsearch内部如何基于_version进行乐观锁并发控制

(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": 2,

    "successful": 1,

    "failed": 0

  },

  "created": true

}

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

{

  "found": true,

  "_index": "test_index",

  "_type": "test_type",

  "_id": "6",

  "_version": 4,

  "result": "deleted",

  "_shards": {

    "total": 2,

    "successful": 1,

    "failed": 0

  }

}

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


©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,915评论 18 139
  • pyspark.sql模块 模块上下文 Spark SQL和DataFrames的重要类: pyspark.sql...
    mpro阅读 9,504评论 0 13
  • 第一百七十八天。 讲好一个故事不容易,这是一个基本的技能。 比如这个故事里面透露藏着信息量就很大了。 自那以后我就...
    何以醉阅读 122评论 0 0
  • 今天给一个学园林的同学看我画的画,她说,还好,画素描需要细致和耐心。我不禁泪目,自己缺的就是这两样啊…… 昨天没有...
    容止有楚楚阅读 268评论 3 4
  • 【目标】2017年轻松喜悦的获得50万的财富 【今日种下的与此目标相关的种子】 1.今天怀着一颗感恩的心继续给快要...
    韩磊_fb71阅读 260评论 0 1