一:分布式锁有哪些实现方式?redis是如何实现分布式锁的?讲一讲Redisson实现分布式锁的原理?
分布式锁可以帮助解决分布式系统中的并发控制和资源访问的问题,确保系统的稳定性和一致性,实现分布式锁的方式有很多,例如:
1.基于MySQL的唯一约束
2.基于Redis的setnx key value
目前使用最广泛的是基于Redis的分布式锁。这个分布式锁是基于Redis的setnx命令实现的,只有Redis中不存在某个key时setnx命令才能成功,否则失败,通过这个特点就可实现简单的分布式锁。
Redisson是基于Redis的功能丰富的框架,它实现分布式锁的流程如下:
首先,尝试加锁。Redisson客户端会通过hash算法选择Redis主从集群中的一个主节点,并执行lua脚本进行加锁。如果加锁不成功,说明已有客户端占用了锁,那么则不停的尝试去加锁。
其次,如果加锁成功,锁的默认生存时间为30S。
之后,Redisson会通过watchdog(看门狗)机制每隔10s监视当前客户端是否持有锁,如果继续持有,则延长生存时间。
最后,释放锁。
二:讲一讲Redisson实现分布式锁的原理
Redis实现分布式锁是通过setnx命令完成的,大体如下:
1.使用setnx key value命令进行加锁,如果key不存在,则加锁成功,如果key存在,则代表已有客户端持有锁,加锁失败
2.解锁时使用del命令删除key,其他客户端需要锁时可以使用setnx命令获取.
三:讲一讲Redisson实现分布式锁的原理
8-2 补充:介绍一下你们项目中的优惠券功能
使用优惠卷功能在我的项目中有以下几个流程。
首先,根据订单查询可用优惠方案,主要判断订单是否符合优惠的条件,例如满减门槛或者是否适用优惠卷的分类。
其次,根据订单和优惠方案查询优惠明细。
然后,核销优惠券。在我的项目中,只能使用一张优惠卷。
最后,退还优惠券。当订单取消或超时后,优惠卷需要退