(五)、Redisson锁机制源码分析

本文深入分析Redisson分布式锁的源码,探讨其加锁、解锁的实现原理,包括锁的互斥性、同一性、可重入性和容错性。重点解析了getLock()、lock()和unlock()方法,以及lua脚本在保证原子性和互斥性中的作用。
摘要由CSDN通过智能技术生成

1、了解分布式锁的特性

  • 1、锁的互斥性
    • 也就是说,在任意时刻,只能有一个客户端能获取到锁,不能同时有两个或多个客户端获取到锁。
    • 简单来说,就比如上厕所,一个厕所只有一个坑位,只能一个人上,不能同时两个人或多个人上。
  • 2、锁的同一性
    • 也就是说,锁只能被持有该锁的客户端进行删除(释放锁),不能由其他客户端删除。
    • 简单俩说,就是谁加的锁,就只能谁来解锁。也就是解铃还须系铃人。
  • 3、锁的可重入性
    • 也就是说,持有某个锁的客户端,可以继续对该锁进行加锁,实现锁的续租。
    • 简单来说,就是你上厕所的按时间收费的,时间快到了会按照时间给你续租,而会给你价钱。
    • 而Redisson则会增大的你的续租次数,也就是可重入次数。但绝不收费,因为Redis是开源的嘛。
  • 4、锁的容错性
    • 锁超过了最大续租时间后,会自动释放锁,其他客户端会继续获得该锁,从而防止死锁的发生。
    • 简单来说,比如你上个厕所上了五小时,厕管员觉得不对劲,就来测试,发现你悄悄逃票了,此时测试会自动
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

码农小何

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值