redis处理分布式锁的封装

github 上面有案例和文档

如果喜欢或者对您有用请帮作者点点关注,并分享给更多的小伙伴

structure-redis

这个项目是对redis相关的封装

主要功能

  • redis分布式锁进行了封装 structure-redis-starter 对spring-boot-starter-data-redis 启动器进行封装

使用方法

pom 引用

        <dependency>
            <groupId>cn.structured</groupId>
            <artifactId>structure-redis-starter</artifactId>
            <version>${last.version}</version>
        </dependency>

使用分布式锁

  • 注解使用分布式锁
  • 手动获取分布式锁
注解使用redis锁 参数为非对象的使用
    /**
     * 注解使用redis锁 参数为非对象的使用
     * @param key
     */
    @RedisLock("#key")
    public void redisLock(String key){
        System.out.println("redisLock ----> key = " + key);
    }
注解使用redis锁 参数为对象的使用
    /**
     * 注解使用redis锁 参数为对象的使用
     * @param redisLockBo
     */
    @RedisLock("#redisLockBo.key")
    public void redisLock(RedisLockBo redisLockBo) {
        System.out.println("redisLock ----> redisLockBo ----> key = " + redisLockBo.getKey());
    }
注解使用redis锁 多个key拼接的key
    /**
     * 注解使用redis锁 多个key拼接的key
     * @param redisLockBo
     */
    @RedisLock("#redisLockBo.key:_#key")
    public void redisLock(RedisLockBo redisLockBo,String key) {
        System.out.println("redisLock ----> redisLockBo ----> key = " + redisLockBo.getKey()+ ":" + key);
    }
手动获取分布式锁的方式 - 更为灵活

    @Resource
    private IDistributedLock iDistributedLock;

    /**
     * 手动处理分布式锁
     */
    public void redisLock() {
        //redis - key
        String key = "123456";
        //获取锁
        boolean lock = iDistributedLock.lock(key);
        //判断是否获取到锁
        if (!lock) {
            return;
        }
        //todo 执行您的业务
        //释放锁
        iDistributedLock.releaseLock(key);
    }
好的,下面是一个简单的Redis分布式锁封装示例: ```python import redis import time class RedisLock: def __init__(self, redis_client, key, expire=60, retry_interval=0.1, retry_times=3): self.redis_client = redis_client self.key = key self.expire = expire self.retry_interval = retry_interval self.retry_times = retry_times self.value = None def __enter__(self): for i in range(self.retry_times): value = str(time.time() + self.expire + 1) if self.redis_client.set(self.key, value, nx=True, ex=self.expire): self.value = value return self time.sleep(self.retry_interval) raise Exception("Failed to acquire lock after retries") def __exit__(self, exc_type, exc_val, exc_tb): if self.value is not None: self.redis_client.eval( "if redis.call('get', KEYS[1]) == ARGV[1] then return redis.call('del', KEYS[1]) else return 0 end", 1, self.key, self.value) ``` 使用方法: ```python redis_client = redis.Redis(host='localhost', port=6379, db=0) key = 'my_lock' with RedisLock(redis_client, key): # 这里是需要加锁保护的代码块 print("Do something with lock") # 锁已经自动释放 ``` 该示例中,`RedisLock`类实现了`__enter__`和`__exit__`方法,使其可以使用Python的`with`语句进行锁的自动管理。在`__enter__`方法中,通过Redis的`set`命令尝试获取锁,如果获取失败,则等待一段时间后重新尝试,最多尝试`retry_times`次。如果在规定的重试次数内仍无法获取到锁,则抛出异常。在获取到锁后,将锁的超时时间设置为`expire`秒,并将锁的值保存在实例中。在`__exit__`方法中,通过调用Redis的`eval`命令,判断锁的值是否为当前实例的值,如果是,则释放锁。 需要注意的是,Redis分布式锁并不是完美的解决方案,仍然存在一些问题,例如死锁、误解锁等。因此,在实际使用时,需要根据具体场景进行设计和优化。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值