环境: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 
}

 

发布评论

分享到:

IT虾米网

微信公众号号:IT虾米 (左侧二维码扫一扫)欢迎添加!

修改$.messager.confirm按钮显示文字详解
你是第一个吃螃蟹的人
发表评论

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。