分布式锁有哪些实现方式?redis是如何实现分布式锁的?讲一讲Redisson实现分布式锁的原理
分布式场景下通过分布式锁来控制并发,每个微服务在多线程的情况下只有一个线程嫩抢到锁,
我了解的分布式锁的实现方式有Mysql的唯一约束和Redis的setnx;
只有Redis中不存在某个key时setnx命令才能成功,否则失败,通过这个特点就可实现简单的分布式锁。
Redisson也可以实现分布式锁:
首先,尝试加锁。Redisson客户端会通过hash算法选择Redis主从集群中的一个主节点、并执行lua脚本进行加锁,加锁不成功,一直自旋尝试加锁。
然后,如果一个线程获取锁成功之后,锁的默认生存时间是30s;Redisson会通过看门狗来监视当前客户端是否持有锁,如果继续持有,会给持有锁的线程每隔10s延长生存时间;
最后,释放锁其他线程抢锁。
介绍下你在项目中的优惠卷功能:
使用优惠卷功能在我的项目中有以下几个流程。
首先根据订单查询可用优惠方案,主要判断订单是否符合优惠的条件,例如满减门槛或者是否适用优惠卷的分类。然后根据订单和优惠方案查询优惠明细,核销优惠券,在我的项目中,只能使用一张优惠卷,最后退还优惠券。当订单取消或超时后,优惠卷需要退回。