基于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();
}
相关推荐
eWidget10 小时前
InfluxDB迁移至金仓数据库的同城容灾实践:性能显著提升、运维效率优化,某能源企业实现RPO_5秒的高可靠时序数据管理
运维·数据库·能源·时序数据库·kingbase·kingbasees·金仓数据库
小句10 小时前
MySQL慢查询日志详细使用指南
数据库·mysql·adb
REDcker11 小时前
Redis容灾策略与哈希槽算法详解
redis·算法·哈希算法
老邓计算机毕设11 小时前
SSM医疗资源普查6qxol(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·javaweb开发·医疗资源管理
dyyx11111 小时前
如何从Python初学者进阶为专家?
jvm·数据库·python
BUTCHER511 小时前
Filebeat输出Kafka配置
分布式·kafka
码农水水11 小时前
中国邮政Java面试被问:容器镜像的多阶段构建和优化
java·linux·开发语言·数据库·mysql·面试·php
曹牧11 小时前
Oracle:NULL
数据库·oracle
龙之叶12 小时前
【Android Monkey源码解析五】- 异常处理
android·数据库
马克学长13 小时前
SSM医院门诊管理系统u4pw5(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm 框架·javaweb 开发·门诊管理