day08

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

       分布式锁: 我们不能让每个实例去使用各自的JVM内部锁监视器,而是应该在多个实例外部寻找一个锁监视器,多个实例争抢同一把锁。像这样的锁,就称为分布式锁。

        实现方式非常多,常用的有两种:

        基于MySQL的唯一约束;

        基于Redis的setnx key value;

        目前使用最广泛的是基于Redis的分布式锁。这个分布式锁是基于Redis的setnx命令实现的,只有Redis中不存在某个key时setnx命令才能成功,否则失败,通过这个特点就可实现简单的分布式锁。当然还存在一些十分复杂的问题,这些解决方案实现起来比较复杂,因此我们通常会使用一些开源框架来实现分布式锁,而不是自己来编码实现。

        redisson的实现原理:

        首先,会尝试加锁,Redis客户端会根据hash算法选择一个节点,并且执行lua脚本进行加锁,如果加锁失败,则会进行重新尝试,加锁成功,锁的默认存活时间为30s,防止加锁程序未完成的情况,在此引入了看门狗(watch dog)机制,每隔10s去查看一次当前客户端是否持有锁,如果有,则会对锁的存活时间进行延长。

        以上就是我对这些问题的回答,谢谢。

2. 补充:介绍一些你们项目中的优惠券功能

        项目中的优惠券还缺少使用这一重要步骤,需要先进行判断,查看购买商品是否符合优惠券的类型,如果符合则可以使用,多张优惠券的情况下只能选择一张优惠券使用,支付折扣之后的响应金额,即可完成商品的购买,若订单超时或取消的情况,则会对优惠券进行返还。

        以上就是优惠券的使用功能,谢谢。

  • 8
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值