• 【无标题】


    分布式锁解决的问题and红锁的问题

    一、其他问题
    分布式锁,当我们请求一个分布式锁的时候,成功了,但是这时候slave还没有复制我们的锁,masterDown了,我们的应用继续请求锁的时候,会从继任了master的原slave上申请,也会成功。

    这就会导致,同一个锁被获取了不止一次。

    二、办法
    Redis中针对此种情况,引入了红锁的概念。

    三、原理
    用Redis中的多个master实例,来获取锁,只有大多数实例获取到了锁,才算是获取成功。具体的红锁算法分为以下五步:

    获取当前的时间(单位是毫秒)。
    使用相同的key和随机值在N个节点上请求锁。这里获取锁的尝试时间要远远小于锁的超时时间,防止某个masterDown了,我们还在不断的获取锁,而被阻塞过长的时间。
    只有在大多数节点上获取到了锁,而且总的获取时间小于锁的超时时间的情况下,认为锁获取成功了。
    如果锁获取成功了,锁的超时时间就是最初的锁超时时间进去获取锁的总耗时时间。
    如果锁获取失败了,不管是因为获取成功的节点的数目没有过半,还是因为获取锁的耗时超过了锁的释放时间,都会将已经设置了key的master上的key删除

    总结:
    分布式系统设计是实现复杂性和收益的平衡,既要尽可能地安全可靠,也要避免过度设计。Redlock 确实能够提供更安全的分布式锁,但也是有代价的,需要更多的 Redis 节点。同时其也并不是百分百安全的依然存在时钟一致性等问题在实际业务中,一般使用基于单点的 Redis 实现分布式锁就可以满足绝大部分的需求,偶尔出现数据不一致的情况,可通过人工介入回补数据进行解决,正所谓“技术不够,人工来凑”!

    redisson的注意事项

    1. 加锁,解锁得在同一个线程——即
      RLock lock = redissonClient.getLock(“test:1”);这里通过客户端获取lcok的时候就是传入了当前的线程id,并绑定在了map中,会将持有锁的线程放入到一个 RedissonLock.EXPIRATION_RENEWAL_MAP里面,然后每隔 10 秒 (internalLockLeaseTime / 3) 检查一下;
      因此不能说,我枷锁了之后,开线程处理,在那个县城里面释放锁
      2.finally里面释放锁的时候,得纯净,不能有异常,否则释放锁失败,这个看门狗无限续期
  • 相关阅读:
    Flutter介绍
    软件工程与计算总结(十三)详细设计中的模块化与信息隐藏
    国区AWS上传本地文件创建私有AMI镜像(无需aws cli)
    解决一个Qt程序崩溃的问题
    【LeetCode】672. 灯泡开关 Ⅱ
    spring复习:(61)自定义CustomAutowireConfigurer
    【OpenGauss源码学习 —— 执行算子(Nest Loop 算子)】
    Centos8部署LNMP架构
    JS踩坑: for let 和 for var的区别
    liunx的基础命令整理
  • 原文地址:https://blog.csdn.net/m0_46598535/article/details/125903448