8-1 分布式锁有哪些实现方式?reids是如何实现分布式锁的?讲一讲Redisson实现分布式锁的原理?
分布式锁是用于分布式场景下控制并发的一种手段。用来保障多个微服务实例,在并发情况下抢锁只能抢到一把锁的一种手段。
我了解的分布式锁实现的方式可以用Mysql的唯一约束(主键也可以),和Redis中的setnx方法
Riedis是跟据 setnx key value 方法实现的,当一个线程过来的时候抢到锁之后,其他的线程,就抢不到锁了。只有当setnx方法主动释放锁的时候才可以进行抢锁。
Redisson是基于Redis的,它实现分布式锁的流程如下:
首先,尝试加锁。加锁、设置过期时间等操作都是基于lua脚本完成(调用redis命令来保证多条命令执行的原子性)
其次,如果一个线程获取锁成功后,锁的默认生存时间为30s;Redisson会通过watchdog(看门狗),监视当前客户端是否持有锁,如果继续持有,会给持有锁的线程每隔10s续期一次;
最后,释放锁。
8-2 补充:介绍一下你们项目中的优惠券功能
使用优惠券功能在我的项目中有以下几个流程:
首先,在订单确认页面查询可用优惠方案,主要判断订单是否符合优惠的条件,例如满减门槛或者是否适用优惠券的分类;
其次,在订单创建页面核销优惠券、查询优惠券优惠明细、查询优惠规则;
最后,当用户取消订单时,还需要退还优惠券;支付后退订单、优惠券则不用退还处理;