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();
        }
    }
相关推荐
爱睡觉的圈圈2 小时前
分布式IP代理集群架构与智能调度系统
分布式·tcp/ip·架构
APItesterCris5 小时前
构建分布式京东商品数据采集系统:基于 API 的微服务实现方案
分布式·微服务·架构
不吃饭的猪6 小时前
kafka启动小脚本
分布式·kafka
休息一下接着来6 小时前
MinIO 分布式模式与纠删码
分布式·minio
胆怯的ai萌新7 小时前
论文阅读/博弈论/拍卖:《Truthful Auction for Cooperative Communications》
分布式·信息与通信
失散139 小时前
分布式专题——10.1 ShardingSphere介绍
java·分布式·架构·shardingsphere·分库分表
阿雄不会写代码11 小时前
分布式部署的A2A strands agents sdk架构中的最佳选择,使用open search共享模型记忆
分布式·架构
许泽宇的技术分享13 小时前
微软图引擎GraphEngine深度解析:分布式内存计算的技术革命
分布式·microsoft
AAA修煤气灶刘哥14 小时前
ES数据同步大乱斗:同步双写 vs MQ异步,谁才是王者?
分布式·后端·elasticsearch
程序消消乐15 小时前
ZooKeeper Multi-op+乐观锁实战优化:提升分布式Worker节点状态一致性
分布式·zookeeper·云原生