elasticsearch6 学习之并发控制

2018-06-18 03:12:38来源:未知 阅读 ()

新老客户大回馈,云服务器低至5折

环境:elasticsearch6.1.2        kibana6.1.2 

并发问题无处不在

一、基于_version 的并发控制

在提交数据前先检查提交数据的version与es中存储的version是否一致,相同则进行更新操作,不同则提示异常信息。

PUT test_index/test_type/1?version=4
{
  "test_name":"book",
  "test_id":111
}

只有当es中存储的这条数据的version=4的时候才能执行成功。

 

二、external version(外部version) 的并发控制

  es提供了一个feature,就是说,你可以不用它提供的内部_version版本号来进行并发控制,可以基于你自己维护的一个版本号来进行并发控制。例如:你的数据在mysql里也有一version,这个时候,你进行乐观锁并发控制的时候,可能并不是想要用es内部的_version来进行控制,而是用你自己维护的那个version来进行控制。

_version:只有当你提供的version与es中的_version一模一样的时候,才可以进行修改,只要不一样,就报错。

external version: 只有当你提供的version比es中的_version大的时候,才能完成修改。

例如:这有一份version=8的数据

{
  "_index": "test_index",
  "_type": "test_type",
  "_id": "1",
  "_version": 8,
  "found": true,
  "_source": {
    "test_name": "book",
    "test_id": 111
  }
}

使用version_type=external 方式替换数据:

PUT /test_index/test_type/1?version=9&version_type=external
{
  "test_name": "update book",
  "test_id":111
}

 

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:SSM+PageHelper 使用

下一篇:java自定义泛型 面试题:接收任意数组进行反转 泛型通配符