基于Redis的分布式锁

一.涉及两个redis命令

1.获取锁

SET 锁的key 锁的value NX EX 秒数

举例:

  • SET:Redis 的基础命令,用于设置键值对
  • lock:键名(这里表示锁的名称,所有竞争同一资源的客户端需使用相同的键名)
  • thread1:键的值(通常用于标识锁的持有者,如客户端 ID、线程 ID 等,用于释放锁时验证身份)
  • NX :选项(全称NOT EXISTS),表示 " 仅在键lock不存在时才执行设置操作 ",确保同一时间只有一个客户端能获取到锁(互斥性核心)
  • EX 10 :选项,表示给键lock设置过期时间为 10 秒(EX单位是秒,PX则表示毫秒),避免客户端因异常未释放锁而导致死锁

2.释放锁

DEL lock

这里表示释放上面的lock锁(删除key为lock的键值对)。

二.流程图

三.使用Java代码,使用一下Redis分布式锁

1.创建接口ILock

java 复制代码
public interface ILock {
    /**
     * 尝试获取锁
     * @param timeoutSec 锁的失效时间,过期则自动释放
     * @return true代表获取锁成功;false代表获取锁失败
     */
    boolean tryLock(long timeoutSec);

    /**
     * 释放锁
     */
    void unlock();
}
相关推荐
haixingtianxinghai3 小时前
Redis真的是单线程吗?
数据库·redis·缓存
若水不如远方3 小时前
分布式一致性(六):拥抱可用性 —— 最终一致性与 Gossip 协议
分布式·后端·算法
FirstFrost --sy3 小时前
MySQL复合查询
数据库·mysql
imuliuliang3 小时前
MySQL的底层原理与架构
数据库·mysql·架构
尽兴-3 小时前
Redis7 底层数据结构解析
数据结构·数据库·缓存·redis7
m0_730115113 小时前
自动化机器学习(AutoML)库TPOT使用指南
jvm·数据库·python
qq_410194294 小时前
SQL语句性能优化
数据库·sql·性能优化
小江的记录本4 小时前
【MyBatis-Plus】Spring Boot + MyBatis-Plus 进行各种数据库操作(附完整 CRUD 项目代码示例)
java·前端·数据库·spring boot·后端·sql·mybatis
wanhengidc4 小时前
《三国志异闻录》搬砖新游戏 云手机
运维·服务器·数据库·游戏·智能手机
2301_807367194 小时前
Python日志记录(Logging)最佳实践
jvm·数据库·python