Redis分布式锁

启动redis
  1. 启动redis进程:/usr/local/bin/redis-server /etc/redis.conf
  2. 进入redis:usr/local/bin/redis-cli
  3. 关闭redis进程:shutdown或者kill -9 进程号
redis分布式锁(共享锁)

总结:先上锁setnx,再加过期时间expire,将value设置成UUID,防止误删,加入LUA脚本保证操作原子性

  1. 命令setnx 上锁 ,del 释放锁 --举例上厕所排队,进去的人上锁,出来之后释放锁,其他人等待

  2. 命令 expire 设置过期时间 —举例如果上厕所睡着了,那么强行解开锁
    在这里插入图片描述

  3. 方式上完锁还没有设置过期时间系统挂掉,可以一条语句 上锁+设置过期时间
    在这里插入图片描述

  4. 优化–防止误删

    情景:a先操作,操作中途卡顿了,锁到时间自动释放,b抢到锁,进行操作时,a不卡顿了,执行完操作,仍然会有释放锁的动作,因为a的锁已经被释放了,会错误的把b的释放掉

    解决方案:使用UUID,释放的时候对比一下,防止误删

  5. 优化—LUA脚本保证操作原子性

    情景:a操作完准备释放锁,先比对UUID是一致的,准备释放,还没有释放的时候,锁到了过期时间,自动释放了,此时就有可能把b的锁释放掉(因为比对UUID的时候是一致的,问题出来了没有原子性,所以加入LUA脚本)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值