分布式锁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方法直接实现.

相关推荐
PD我是你的真爱粉9 分钟前
MySQL基础-DQL语句与多表查询
数据库·mysql
C#程序员一枚16 分钟前
SqlServer如何创建全文索引
数据库·sqlserver
DBA小马哥36 分钟前
时序数据库迁移实践指南:面向业务连续性的技术演进路径
数据库·时序数据库·dba
生命因何探索44 分钟前
Redis-持久化
数据库·redis·缓存
文艺倾年1 小时前
【免训练&测试时扩展】通过任务算术转移思维链能力
人工智能·分布式·算法
yjb.gz1 小时前
Shell实现数据库巡检
数据库
福大大架构师每日一题2 小时前
redis 8.4.1 正式发布:安全升级、性能强化与多模块重大修复详解
数据库·redis·安全
魑-魅-魍-魉2 小时前
金仓数据库(KingbaseES)Windows 安装避坑指南:从 Connection Refused 到服务启动的完整实战记录
数据库·金仓
chlk1233 小时前
聊聊索引:为何 B + 树能撑起数据库的半壁江山?
数据库·mysql
宁酱醇3 小时前
ORACLE_建表+增改查+删
数据库·oracle