【Redisson分布式锁】基于redisson的分布式锁

redisson分布式锁

maven文件:

java 复制代码
        <dependency>
            <groupId>org.redisson</groupId>
            <artifactId>redisson-spring-boot-starter</artifactId>
            <version>3.15.3</version>
        </dependency>

实现代码:

分布式锁对象参数(DistributedLock):

java 复制代码
import lombok.Data;

import java.util.concurrent.TimeUnit;

/**
 * 分布式锁对象参数
 */
@Data
public class DistributedLock {
    /**
     * 锁用的key
     */
    private String lockKey;
    /**
     * 等待(尝试)时间,默认3秒
     */
    private long waitTime=3;
    /**
     *加锁的时间,默认20秒
     */
    private long lockTime=20;
    /**
     * 时间单位:默认秒
     */
    private TimeUnit timeUnit= TimeUnit.SECONDS;
}

配置:LockAutoConfig

java 复制代码
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;

@Configuration
@ComponentScan(basePackages = "com.xxx.commons.rlockstater")
public class LockAutoConfig {
    @Bean
    public DistributedLockService distributedLockService(){
        return new DistributedLockServiceImpl();
    }
}

DistributedLockService

java 复制代码
import org.redisson.api.RLock;

public interface DistributedLockService {

    /**
     * 获取锁
     * @param distributedLock 分布式锁对象参数
     * @return boolean
     */
    public boolean tryLock(DistributedLock distributedLock);

    /**
     * 解(释放)锁
     * @param distributedLock 分布式锁对象参数
     */
    public void unlock(DistributedLock distributedLock);
    /**
     * 解(释放)锁
     * @param lockKey 锁的key值
     */
    public void unlock(String lockKey);

    /**
     * 解(释放)锁
     * @param lock 锁对象
     */
    public void unlock(RLock lock);
}

实现:

DistributedLockServiceImpl:

java 复制代码
import lombok.extern.slf4j.Slf4j;
import org.redisson.api.RLock;
import org.redisson.api.RedissonClient;
import org.springframework.beans.factory.annotation.Autowired;

@Slf4j
public class DistributedLockServiceImpl implements DistributedLockService {
    /**
     * 默认的LockKey前缀
     */
    private static final String LOCK_KEY_PREFIX = "tincere:rlock";
    private RedissonClient redissonClient;

    @Autowired
    public void setRedissonClient(RedissonClient redissonClient) {
        this.redissonClient = redissonClient;
    }

    @Override
    public boolean tryLock(DistributedLock distributedLock) {
        try {
            RLock lock = redissonClient.getLock(LOCK_KEY_PREFIX + distributedLock.getLockKey());
            return lock.tryLock(distributedLock.getWaitTime(), distributedLock.getLockTime(), distributedLock.getTimeUnit());
        } catch (Exception e) {
            log.error("获取分布式锁异常", e);
        }
        return false;
    }

    @Override
    public void unlock(DistributedLock distributedLock) {
        RLock lock = redissonClient.getLock(LOCK_KEY_PREFIX + distributedLock.getLockKey());
        unlock(lock);
    }

    @Override
    public void unlock(String lockKey) {
        RLock lock = redissonClient.getLock(LOCK_KEY_PREFIX + lockKey);
        unlock(lock);
    }

    @Override
    public void unlock(RLock lock) {
        if(!lock.isLocked()||!lock.isHeldByCurrentThread()){
            log.error("当前Key{}不存在或者不是当前线程持有",lock.getName());
            return;
        }
        lock.unlock();
    }
}
相关推荐
qq_12498707533 小时前
基于Hadoop的信贷风险评估的数据可视化分析与预测系统的设计与实现(源码+论文+部署+安装)
大数据·人工智能·hadoop·分布式·信息可视化·毕业设计·计算机毕业设计
Coder_Boy_5 小时前
基于Spring AI的分布式在线考试系统-事件处理架构实现方案
人工智能·spring boot·分布式·spring
袁煦丞 cpolar内网穿透实验室6 小时前
远程调试内网 Kafka 不再求运维!cpolar 内网穿透实验室第 791 个成功挑战
运维·分布式·kafka·远程工作·内网穿透·cpolar
人间打气筒(Ada)7 小时前
GlusterFS实现KVM高可用及热迁移
分布式·虚拟化·kvm·高可用·glusterfs·热迁移
xu_yule7 小时前
Redis存储(15)Redis的应用_分布式锁_Lua脚本/Redlock算法
数据库·redis·分布式
難釋懷11 小时前
分布式锁的原子性问题
分布式
ai_xiaogui12 小时前
【开源前瞻】从“咸鱼”到“超级个体”:谈谈 Panelai 分布式子服务器管理系统的设计架构与 UI 演进
服务器·分布式·架构·分布式架构·panelai·开源面板·ai工具开发
凯子坚持 c12 小时前
如何基于 CANN 原生能力,构建一个支持 QoS 感知的 LLM 推理调度器
分布式
飞升不如收破烂~12 小时前
Redis 分布式锁+接口幂等性使用+当下流行的限流方案「落地实操」+用户连续点击两下按钮的解决方案自用总结
数据库·redis·分布式