基于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();
}
相关推荐
有味道的男人1 小时前
对接亚马逊平台接口,商品全量信息一键抓取
数据库
Web极客码1 小时前
2026年Linux VPS安全加固清单:SSH、防火墙与审计就绪配置
运维·服务器·数据库
逻辑驱动的ken3 小时前
Java高频面试考点18
java·开发语言·数据库·算法·面试·职场和发展·哈希算法
qq_392690663 小时前
Redis怎样应对Redis集群整体宕机带来的雪崩
jvm·数据库·python
快乐非自愿3 小时前
Redis--SDS字符串与集合的底层实现原理
数据库·redis·缓存
这儿有一堆花4 小时前
住宅代理(Residential Proxy)技术指南
开发语言·数据库·php
茉莉玫瑰花茶4 小时前
LangChain 核心组件 [ 2 ]
java·数据库·langchain
存在的五月雨5 小时前
Mysql 索引的一些
数据库·mysql
无小道5 小时前
Redis——特性
redis
黄俊懿5 小时前
MySQL主从复制:从“异步“到“GTID“,数据同步的进化之路
数据库·sql·mysql·oracle·架构·dba·db