分布式锁 之 redission

文章展示了如何配置Redisson客户端连接Redis服务器,包括设置主机、端口、数据库和密码。在代码中,还演示了如何使用RLock并讨论了tryLock方法的参数,特别是看门狗的失效情况,指出当设置租期时,看门狗不会自动续期。

<dependency>
    <groupId>org.redisson</groupId>
    <artifactId>redisson</artifactId>
    <version>3.13.6</version>
</dependency>

@Configuration
public class RedissionConfig {

    @Value("${spring.redis.host}")
    private String redisHost;

    @Value("${spring.redis.password}")
    private String password;

    @Value("${spring.redis.port}")
    private int port;

    @Value("${spring.redis.database}")
    private int database;

    @Bean
    public RedissonClient getRedisson() {
        Config config = new Config();
        SingleServerConfig serverConfig = config.useSingleServer()
                .setAddress("redis://" + redisHost + ":" + port)
                .setDatabase(database);
        if (StrUtil.isNotEmpty(password)) {
            serverConfig.setPassword(password);
        }
        config.setCodec(new JsonJacksonCodec());
        return Redisson.create(config);
    }
}

使用

@Resource
private RedissonClient redissonClient;
    public void testLock() {
        RLock lock = redissonClient.getLock("key");
        try {

            boolean lockFlag = lock.tryLock(0, -1, TimeUnit.SECONDS);

            System.out.println(DateUtil.now() + "  " + lockFlag);
        } catch (Exception e) {
        } finally {
           lock.unlock();
        }
    }

redission的看门狗失效问题

/**
*  waitTime 尝试获取锁的最大等待时间,超过这个值,则认为获取锁失败
*  leaseTime 这个参数字段表示租期,只要设置了租期,那么看门狗就失效了,不会续期
*/
boolean lockFlag = lock.tryLock(0, -1, TimeUnit.SECONDS);

回答: Redis分布式锁Redission都是解决高并发中分布式锁的问题的方法。Redis分布式锁是通过使用K-V存储来判断是否拥有锁,避免了释放他人的锁的问题。当业务没有执行完毕但是锁已经过期时,可以采用守护线程的方式来定期检查锁是否过期,并延长锁的过期时间,也就是锁的续期机制。而Redission是一种实现分布式锁的解决方案,它首先获取锁,然后尝试加锁,加锁成功后执行业务逻辑,最后释放锁。Redission解决了Redis实现分布式锁中的锁过期和释放他人锁的问题,通过内部机制和看门狗机制来保证锁的有效性。然而,Redission在Redis主从架构下存在高一致性问题,解决高一致性问题可以使用红锁或者zk锁,但这可能会牺牲高可用性。总的来说,Redis分布式锁Redission都是解决高并发中分布式锁的方法,但需要根据具体情况选择合适的方案。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Redis和Redission两种方式实现分布锁](https://blog.youkuaiyun.com/weixin_45150104/article/details/125131846)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值