Redis分布式锁释放锁是否必须用lua脚本?

无lua脚本释放锁:

java 复制代码
public void unlock(String key, String uniqueValue) {
	String value =redisDao.getString(key);
	if (value != null && value.equals(uniqueValue))
		redisDao.delete(key);
}

使用lua脚本释放锁:

java 复制代码
	// LUA脚本 -> 分布式锁解锁原子操作脚本
    private static final String LUA_SCRIPT =
            "if redis.call('get',KEYS[1]) == ARGV[1] then" +
                    " return redis.call('del',KEYS[1]) " +
                    "else" +
                    " return 0 " +
                    "end";
    // lockId 一个不重复id -> 区分不同客户端
    public boolean unlock(String lockId) {
        Jedis client = jedisPool.getResource();
        try {
            Object result = client.eval(LUA_SCRIPT, Arrays.asList(LOCK_KEY), Arrays.asList(lockId));
            if (result != null && "1".equalsIgnoreCase(result.toString())) {
                return ture;
            }
            return false;
        } catch (Exception e) {
            e.printStackTrace();
            log.error(e.getMessage());
        }
        return false;
    }

在释放锁的时候,如果没用原子操作,那么取值、比较、删除是三步操作。

假设现在是线程A在执行当前的动作。如果线程A取值之后,删除操作之前,key正好过期了,那么锁就自动释放了。这时,又被另外一个线程B获取了锁,那么在删除操作时,就会把线程B的锁给删除掉。如果这时线程B还在执行中,因为线程B的锁被线程A给删除掉了,那么其他的线程C也就可以获取到锁了。这样,其实临界区就有多个线程在运行了。

相关推荐
xrkhy1 小时前
canal1.1.8+mysql8.0+jdk17+redis的使用
android·redis·adb
Luke Ewin2 小时前
内网私有化分布式集群部署语音识别接口
人工智能·分布式·语音识别·asr·funasr·通话语音质检·区分说话人
小马爱打代码3 小时前
实战:分布式开源监控Zabbix
分布式·开源·zabbix
筑梦之人4 小时前
Spark-3.5.7文档2 - RDD 编程指南
大数据·分布式·spark
happy_king_zi5 小时前
RabbitMQ 是否也支持消费组
分布式·rabbitmq
兮动人7 小时前
PrettyZoo:优雅易用的 ZooKeeper 可视化管理工具
分布式·zookeeper·云原生·prettyzoo
MuYiLuck7 小时前
redis持久化与集群
java·数据库·redis
回家路上绕了弯7 小时前
五分钟内重复登录 QQ 号定位:数据结构选型与高效实现方案
分布式·后端
埃泽漫笔7 小时前
Redis性能优化避坑指南
redis
升鲜宝供应链及收银系统源代码服务8 小时前
升鲜宝生鲜配送供应链管理系统--- 《多语言商品查询优化方案(Redis + 翻译表 + 模糊匹配)》
java·数据库·redis·bootstrap·供应链系统·生鲜配送·生鲜配送源代码