Elasticsearch基于乐观锁解决并发冲突问题

场景

假设有这样一个场景:进程a从es集群里读取商品数据goods,修改后再次存到es中,与此同时,其他多个进程(进程b、c…)也在执行相同的操作,如何解决多进程并发操作。
比如下面这个场景:
在这里插入图片描述

悲观锁和乐观锁

对于这种高并发问题,有悲观锁和乐观锁两种解决方案。

  • 悲观锁:每个线程进行数据操作时,都进行加锁,加锁之后,只有这个进行能操作数据。对程序来说,简单透明,,不需要额外的操纵,但是缺点也很明显,并发能力很低,同一时间只有一个进程能操作数据;
  • 乐观锁:不需要加锁,每次读取数据和修改数据时会比对版本号,如果前后版本号发生变化,则本次修改丢弃,再重复一次操作,好处是可以大量线程进行并发操作,缺点是麻烦,每次更新需要比对版本号,还可能重复进行操作;

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值