redis的锁

redis分布式锁

分布式锁:在分布式系统下保证多线程互斥并可见;即让不同服务器的线程共同使用一把锁

分布式锁的缺陷

锁失效:持有锁是client 1由于网络原因陷入阻塞,业务为执行完锁便过期

时钟漂移:Client 1 获取锁后,定义了过期时间,由于redis本身时钟若比Client不同可能产生锁相对于redis提前失效,但client还持有锁,此时Client 2再次分配到锁,就会出现多线程同有一把琐的情况

redis实现分布式锁

利用redis的SETNX命令,该命令为原子性操作,只有Key不存在,Set才能获取成功;具体流程为:

  1. 获取当前时间

  2. 依次N个节点获取锁,设置锁响应超时时间

  3. 在锁的过期时间内,成功获取锁的节点数大于N/2 + 1,说明获取锁成功;

  4. 若获取锁失败,则向所有结点释放锁

redis的加锁机制:SETNX命令

SETNX:SET if Not eXists:如果不存在则set;

使用ex设置超时时间

sql 复制代码
#在添加时存在则添加,不存在则不添加。同时设置过期时间,单位秒
SET key value NX EX time

Lua脚本为什么能够保证原子性:

Lua脚本能够保证原子性的主要原因还是Redis采用了单线程执行模型 。也就是说,当Redis执行Lua脚本时,Redis会把Lua脚本作为一个整体并把它当作一个任务加入到一个队列中,然后单线程按照队列的顺序依次执行这些任务,在执行过程中Lua脚本是不会被其他命令或请求打断,因此可以保证每个任务的执行都是原子性的

相关推荐
Lovyk2 小时前
基于 Ansible 与 Jinja2 模板的 LNMP 环境及 WordPress 自动化部署实践
linux·运维·服务器·自动化·ansible
知白守黑2673 小时前
Linux磁盘阵列
linux·运维·服务器
tan77º5 小时前
【项目】分布式Json-RPC框架 - 项目介绍与前置知识准备
linux·网络·分布式·网络协议·tcp/ip·rpc·json
BYSJMG5 小时前
计算机大数据毕业设计推荐:基于Hadoop+Spark的食物口味差异分析可视化系统【源码+文档+调试】
大数据·hadoop·分布式·python·spark·django·课程设计
TPBoreas6 小时前
Jenkins启动端口修改失败查找日志
运维·服务器·jenkins
TT哇6 小时前
@[TOC](计算机是如何⼯作的) JavaEE==网站开发
java·redis·java-ee
蚰蜒螟7 小时前
Spring 和 Lettuce 源码分析 Redis 节点状态检查与失败重连的工作原理
java·redis·spring
正在努力的小河7 小时前
Linux设备树简介
linux·运维·服务器
小张快跑。8 小时前
Tomcat下载、安装及配置详细教程
java·服务器·tomcat
Viking_bird8 小时前
Apache Spark 3.2.0 开发测试环境部署指南
大数据·分布式·ajax·spark·apache