Redisson分布式锁解决方案

官方地址


官网: https://redisson.org

github: https://github.com/redisson/redisson

基于setnx实现的分布式锁存在的问题


redisson分布式锁原理

  • 不可重入: 利用hash结构记录线程id和重入次数
  • 不可重试: 利用信号量和PubSub功能实现等待、唤醒, 获取锁失败的重试机制
  • 超时释放: 利用WatchDog, 每隔一段时间(releaseTime/3), 重置超时时间

依赖和配置


  • 引入依赖
xml 复制代码
		<dependency>
            <groupId>org.redisson</groupId>
            <artifactId>redisson</artifactId>
            <version>3.13.6</version>
        </dependency>
  • 配置
java 复制代码
	@Bean
    public RedissonClient redissonClient(){
        Config config = new Config();
        // 添加redis地址, 这里添加了单点的地址, 也可以用config.useClusterServers()添加集群地址
        config.useSingleServer().setAddress("redis://localhost:6379").setPassword("123456");
        return Redisson.create(config);
    }
  • 三台单点redis服务
java 复制代码
	@Bean
    public RedissonClient redissonClient(){
        Config config = new Config();
        // 添加redis地址, 这里添加了单点的地址, 也可以用config.useClusterServers()添加集群地址
        config.useSingleServer().setAddress("redis://localhost:6379").setPassword("123456");
        return Redisson.create(config);
    }

    @Bean
    public RedissonClient redissonClient2(){
        Config config = new Config();
        // 添加redis地址, 这里添加了单点的地址, 也可以用config.useClusterServers()添加集群地址
        config.useSingleServer().setAddress("redis://localhost:6380").setPassword("123456");
        return Redisson.create(config);
    }

    @Bean
    public RedissonClient redissonClient3(){
        Config config = new Config();
        // 添加redis地址, 这里添加了单点的地址, 也可以用config.useClusterServers()添加集群地址
        config.useSingleServer().setAddress("redis://localhost:6381").setPassword("123456");
        return Redisson.create(config);
    }
java 复制代码
	RLock multiLock;

    @BeforeEach
    void setUp() {
        RLock lock = redissonClient.getLock("xiaoyuxia");
        RLock lock2 = redissonClient2.getLock("xiaoyuxia");
        RLock lock3 = redissonClient3.getLock("xiaoyuxia");
        multiLock = redissonClient.getMultiLock(lock, lock2, lock3);
    }

    @Test
    void test() throws Exception {
        boolean b = multiLock.tryLock();
        try {
            if (b) {
                // TODO
            }
        } finally {
            multiLock.unlock();
        }
    }
相关推荐
想你依然心痛10 小时前
HarmonyOS 5.0工业物联网开发实战:构建分布式智能制造监控与数字孪生预测维护系统
分布式·物联网·harmonyos·数字孪生
zhixingheyi_tian10 小时前
Hadoop 之 native 库
大数据·linux·hadoop·分布式
蓝魔Y10 小时前
Apache—Kafka实践
分布式·kafka·apache
七夜zippoe10 小时前
DolphinDB数据模型:表、分区与分布式表
分布式·wpf·数据模型··dolphindb
ZC跨境爬虫10 小时前
纯requests+Redis实现分布式爬虫(可视化4终端,模拟4台电脑联合爬取)
redis·分布式·爬虫·python
rit84324991 天前
单向拓扑结构下异构车辆排的分布式模型预测控制(DMPC)
分布式
我要用代码向我喜欢的女孩表白1 天前
在spark集群上在部署一套spark环境,不要影响过去环境
大数据·分布式·spark
2603_954708311 天前
多微电网系统架构:集群协同与能量互济的网络设计
网络·人工智能·分布式·物联网·架构·系统架构
8Qi81 天前
RabbitMQ高级篇:消息可靠性、幂等性与延迟消息
java·分布式·微服务·中间件·rabbitmq·springcloud
互联网散修1 天前
鸿蒙跨设备实时绘图同步:从零到一实现分布式画板
分布式·wpf·harmonyos