day08业务题

本文介绍了分布式锁的两种实现方式,重点讨论了Redis基于setnx的实现和Redisson框架的加锁机制。同时,详细描述了项目中优惠券功能的流程,包括查询可用优惠方案、核销及退款过程。
摘要由CSDN通过智能技术生成

8-1 分布式锁有哪些实现方式?Redis是如何实现分布式锁的?讲一讲Redisson实现分布式锁的原理?
在分布式系统中,我们不能让每个实例去使用各自的JVM内部锁监视器,而是应该在多个实例外部寻找一个锁监视器,多个实例争抢同一把锁。像这样的锁,就称为分布式锁。我了解的分布式锁有两种实现方式:①基于MySQL的唯一约束。②基于Redis的setnx key value。

目前使用最广泛的是基于Redis的分布式锁。这个分布式锁是基于Redis的setnx命令实现的,只有Redis中不存在某个key时setnx命令才能成功,否则失败,通过这个特点就可实现简单的分布式锁。

Redisson是基于Redis的功能丰富的框架,它实现分布式锁的流程如下:

首先,尝试加锁。Redisson客户端会通过hash算法选择Redis主从集群中的一个主节点,并执行lua脚本进行加锁。如果加锁不成功,说明已有客户端占有了锁,那么则循环不停尝试枷锁。

其次,如果枷锁成功,锁的默认生存时间为30S。

之后,Redisson会通过watchdog(看门狗)机制每隔10s监视当前客户端是否持有锁,如果继续持有,则延长生存时间。

最后,释放锁。

8-2 补充:介绍下你在项目中的优惠卷功能。
使用优惠卷功能在我的项目中有以下几个流程。

首先,根据订单查询可用优惠方案,主要判断订单是否符合优惠的条件,例如满减门槛或者是否适用优惠卷的分类。

其次,根据订单和优惠方案查询优惠明细。

然后,核销优惠券。在我的项目中,只能使用一张优惠卷。

最后,退还优惠券。当订单取消或超时后,优惠卷需要退回。

  • 9
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值