您的位置:首页 > 财经 > 产业 > 郑州通告最新_前端兼职接单平台_网站seo优化建议_今日最新消息

郑州通告最新_前端兼职接单平台_网站seo优化建议_今日最新消息

2024/12/26 2:25:01 来源:https://blog.csdn.net/qq_43954910/article/details/144661387  浏览:    关键词:郑州通告最新_前端兼职接单平台_网站seo优化建议_今日最新消息
郑州通告最新_前端兼职接单平台_网站seo优化建议_今日最新消息

无lua脚本释放锁:

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

使用lua脚本释放锁:

	// 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也就可以获取到锁了。这样,其实临界区就有多个线程在运行了。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com