elasticsearch6 学习之并发控制
2018-06-18 03:12:38来源:未知 阅读 ()
环境: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
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- java学习之第一天 2020-06-11
- Java学习之第二天 2020-06-11
- 那些面试官必问的JAVA多线程和并发面试题及回答 2020-05-28
- 【JavaSE】多线程与并发编程(总结) 2020-05-25
- Java并发编程volatile关键字 2020-05-24
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash