day08

8-1 分布式锁有哪些实现方式? redis是如何实现分布式锁的? 讲一讲Redisson实现分布式锁的原理

分布式锁是分布式场景下控制并发的一种手段,保证微服务在并发情况下抢锁只能抢一个;我了解的分布式锁的实现方式有mysql的唯一约束和redis的setnx;

       Redis实现分布式锁主要有以下几步:

       客户端通过执行setnx命令来获取锁。 在高并发的情况下,只有一个客户能够成功执行命令,从而获取到锁;

       别的客户只能等这个客户在完成任务后执行del命令释放锁后才能获取锁。

       Redisson是基于Redis的,它实现分布式锁的流程如下:

       首先,尝试加锁。加锁、设置过期时间等操作都是基于lua脚本完成(调用redis命令来保证多条命令执行的原子性)

       其次,如果一个线程获取锁成功后,锁的默认生存时间为30s;Redisson会通过watchdog(看门狗),监视当前客户端是否持有锁,如果继续持有,会给持有锁的线程每隔10s续期一次;

       最后,释放锁。

8-2 补充昨天优惠券的使用

使用优惠券功能在我的项目中有以下几个流程:

       首先,在订单确认页面查询可用优惠方案,主要判断订单是否符合优惠的条件,例如满减门槛或者是否适用优惠券的分类;

       然后,在订单创建页面核销优惠券、查询优惠券优惠明细、查询优惠规则;

       最后,当用户取消订单时,还需要退还优惠券;支付后退订单、优惠券则不用退还处理;

       以上就是我项目中使用优惠券的实现。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值