ES 知识点

一、ES基于_version 进行乐观锁并发控制post /index/type/id/_update?retry_on_conflict=5&version=61.内部版本号第一次创建document的version版本号为1,以后每次对这个document修改或删除操作,version自动加1。同时带上数据的版本号,确保es中数据的版本号,跟客户端中的数据的版本号是相同...
摘要由CSDN通过智能技术生成

一、ES基于_version 进行乐观锁并发控制

post /index/type/id/_update?retry_on_conflict=5&version=6

1.内部版本号

第一次创建document的version版本号为1,以后每次对这个document修改或删除操作,version自动加1。

同时带上数据的版本号,确保es中数据的版本号,跟客户端中的数据的版本号是相同的,才能修改。

可以指定更新失败之后的重试次数:retry_on_conflict,版本冲突时重试次数

## 2.external version

可以基于你自己维护的一个版本号来进行并发控制。举个列子,加入你的数据在mysql里也有一份,然后你的应用系统本身就维护了一个版本号,无论是什么自己生成的,程序控制的。这个时候,你进行乐观锁并发控制的时候,可能并不是想要用es内部的_version来进行控制,而是用你自己维护的那个version来进行控制。

 

二、document路由原理

1.路由算法

 

2.决定document在哪个shard上,最主要的就是routing的值,默认是id,也可以手动指定。

3.这就是primary shard 不可变的原因

 

三、写一致性原理

put /index/type/id?consistency=quorum

1.one

要求我们这个写操作,只要有一个primary shard是活跃可用的,就可以执行。

2.all

要求我们这个写操作,必须所有的primary shard和replica shrad 都是活跃的,才可以执行这个写操作。

3.quorun

默认

要求我所有的shard中,大部分的都是活跃可用的,才可以执行。 (1个节点除外)

算法

 

说明࿱

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值