分布式锁的三种实现方式

12 篇文章 0 订阅
5 篇文章 0 订阅

分布式锁实现方式主要有三种,数据库,Redis 和 ZooKeeper。

1、数据库实现分布式锁

使用select field from table_name  where idx = n for update

关键词 for update,如果 idx为主键或索引字段,这样就会使用行锁,相同记录进行操作会阻塞,等待锁释放后才能继续,可以设置超时时间,如 for update 2s,获取不到锁就报异常。这种方式不会影响对其他行的 write 操作,也不会影响对表数据的 read 操作,不建议并发量很大的情况下使用,用户体验不好。

2、Redis 实现分布式锁

setnx方法,指定 key 不存在时设置 value,如果已存在,直接报错,简单粗暴。因为加锁,超时,释放锁分别设置,不是原子操作,正常情况下设置超时时间,这样即使程序异常没有手动释放锁,也可以实现一定时间后自动释放锁。

3、ZooKeeper 实现分布式锁

使用zk原生API实现分布式锁比较麻烦,可以直接使用Curator,简单的API就可以实现。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值