栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

分布式锁总结

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

分布式锁总结

1 概念

        对于一个单机的系统,我们可以通过synchronized或者ReentrantLock等这些常规的加锁方式来实现,然而对于一个分布式集群的系统而言,单纯的本地锁已经无法解决问题,所以就需要用到分布式锁了

2 锁的属性

        分布式锁要保证互斥性、不死锁、可重入等特点。

  • 互斥性 :  对于同一个资源,任意时刻,都只有一个客户端能持有锁。
  • 不死锁 : 必须要有锁超时这种机制,保证在出现问题的时候释放锁,不会出现死锁的问题。
  • 可重入 : 指的是对于同一个线程,可以多次重复加锁。

3 Redis 分布式锁

可以使用 setNX命令上锁

3.1 锁超时问题
        3.1.1 问题描述

比如客户端A加锁同时设置超时时间是3秒,结果3s之后程序逻辑还没有执行完成,锁已经释放。客户端B此时也来尝试加锁,那么客户端B也会加锁成功。

这样的话,就导致了并发的问题,如果代码幂等性没有处理好,就会导致问题产生。

       

        3.1.2 解决方案
  1. 针对锁超时的问题,我们可以根据平时业务执行时间做大致的评估,然后根据评估的时间设置一个较为合理的超时时间,这样能一大部分程度上避免问题。

  2. 自动续租,通过其他的线程为将要过期的锁延长持有时间

3.2 锁误删除

        3.2.1 问题描述

        还是类似的问题,客户端A加锁同时设置超时时间3秒,结果3s之后程序逻辑还没有执行完成,锁已经释放。客户端B此时也来尝试加锁,这时客户端A代码执行完成,执行释放锁,结果释放了客户端B的锁。

        3.2.2 解决方案

        每个客户端的锁只能自己解锁,一般我们可以在使用set命令的时候生成随机的value,解锁使用lua脚本判断当前锁是否自己持有的,是自己的锁才能释放。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/686029.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号