分布式锁2:基于redis实现分布式锁

一 redis实现分布式锁

1.1 原理

setnx+expire+del 命令实现redis的分布式锁;其中 setnx 不存在则新增;存在则忽略。即先用setnx来抢锁,如果抢到之后,再用expire给锁设置一个过期时间,防止锁忘记了释放。例如:

setnx lock 111 ex 20 nx

**但是如果expire无法执行, 会导致死锁,**redis中setnx+expire是非原子操作, 除了用LUA脚本保证实现原子操作, 其实可以直接使用redis自带的set方法直接实现.

相关推荐
coderlin_几秒前
Langgraph项目三 agent搭建
java·数据库·redis
xyx-3v3 分钟前
信号量(二进制/计数)
java·linux·数据库
u01102251212 分钟前
HTML5多媒体资源动态替换Source标签的刷新机制
jvm·数据库·python
云祺vinchin16 分钟前
“十五五”引领灾备升级,数字化安全建设如何合规落地?
网络·数据库·安全·kubernetes·数据安全·容灾备份
当战神遇到编程17 分钟前
关系型数据库设计基础:约束、三大范式、表关系与表设计流程
数据库
其实防守也摸鱼25 分钟前
《SQL注入进阶实验:基于sqli-Labs的报错注入(Error-Based Injection)实战解析》
网络·数据库·sql·安全·网络安全·sql注入·报错注入
Ting.~27 分钟前
软件设计师备考笔记【day3】-数据库
数据库·笔记
Bert.Cai27 分钟前
MySQL FLOOR()函数详解
数据库·mysql
小碗羊肉36 分钟前
【MySQL | 第七篇】索引
数据库·mysql
juniperhan38 分钟前
Flink 系列第20篇:Flink SQL 语法全解:从 DDL 到 DML,窗口、聚合、列转行一网打尽
大数据·数据仓库·分布式·sql·flink