码迷,mamicode.com
首页 > 其他好文 > 详细

6:Partial Update 内部原理 和 乐观锁并发控制

时间:2019-06-16 21:32:23      阅读:166      评论:0      收藏:0      [点我收藏+]

标签:冲突   控制   过程   根据   简单   并发   生成   不可   conf   

Partial Update 内部执行过程:
  1. 首先,ES文档是不可变的,它们只能被修改,不能被替换。Update Api 也不例外。
  2. Update API 简单使用与之前描述相同的 检索-修改-重建索引(reindex) 的处理过程。 区别在于这个过程发生在分片内部。
  3. 相当于ES的Shard内部 执行了 Get(获取该文档所有数据),CreateDoc(根据请求生成新文档),Put(把新文档写入ES)。如果使用全量替换,这3个步骤会发生在Java程序里,但如果使用partial update,ES则会帮我们做这些事。
 
Partial Update的好处:
  1. 把原来的3次网络请求转换为1次,降低网络负荷
  2. 使Java程序逻辑变得简单
  3. 由于 检索 和 重建索引 发生在 shard内,这两个步骤时间间隔小,大大降低冲突的可能
 
并发问题:
    1. 检索 和 重建索引(reindex) 步骤的间隔越小,变更冲突的机会越小。 但是它并不能完全消除冲突的可能性。 还是有可能在 update 设法重新索引之前,来自另一进程的请求修改了文档。
    2. 因此,ES内部也参照Java步骤,实现了基于version的乐观锁控制并发。
    3. 我们可以对ES内部的乐观锁,设置一些参数:
    并发冲突后,允许重试的次数:retry_on_conflict
POST /test_index/test_type/1/_update?retry_on_conflict=5
{
    "doc":{
        "num":20
    }
}
 

6:Partial Update 内部原理 和 乐观锁并发控制

标签:冲突   控制   过程   根据   简单   并发   生成   不可   conf   

原文地址:https://www.cnblogs.com/cc299/p/11032809.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!