我是靠谱客的博主 老实溪流,最近开发中收集的这篇文章主要介绍Php避免redis死锁,如何写出防止死锁的redis锁!附源代码,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

正确的加锁方式(很多人以为下面代码多的是正确的加锁方式,其实redis已经解决这个问题了):

// 这里使用集成的jedis

jedis.set(String key, String value, String nxxx, String expx, int time)

错误的加锁方式1:

//如果程序在执行完setnx()之后突然崩溃,导致锁没有设置过期时间。那么将会发生死锁。

Long result = jedis.setnx(Key, value);

if (result == 1) {

// 若在这里程序突然崩溃,则无法设置过期时间,将发生死锁

jedis.expire(Key, expireTime);

}

错误的加锁方式2:

​分布式锁才用(Key,过期时间)的方式,如果锁存在,那么获取它的过期时间,如果锁的确已经过期了,那么获得锁,并且设置新的过期时间

错误分析:不同的客户端之间需要同步好时间。

long expires = System.currentTimeMillis() + expireTime;

String expiresStr = String.valueOf(expires);

// 如果当前锁不存在,返回加锁成功

if (jedis.setnx(lockKey, expiresStr) == 1) {

return true;

}

// 如果锁存在,获取锁的过期时间

String currentValueStr = jedis.get(lockKey);

if (currentValueStr != null && Long.parseLong(currentValueStr) < System.currentTimeMillis()) {

// 锁已过期,获取上一个锁的过期时间,并设置现在锁的过期时间

String oldValueStr = jedis.getSet(lockKey, expiresStr);

if (oldValueStr != null && oldValueStr.equals(currentValueStr)) {

// 考虑多线程并发的情况,只有一个线程的设置值和当前值相同,它才有权利加锁

return true;

}

}

// 其他情况,一律返回加锁失败

return false;

解锁:判断锁的拥有者后可以使用 jedis.del(lockKey) 来释放锁。

最后

以上就是老实溪流为你收集整理的Php避免redis死锁,如何写出防止死锁的redis锁!附源代码的全部内容,希望文章能够帮你解决Php避免redis死锁,如何写出防止死锁的redis锁!附源代码所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(47)

评论列表共有 0 条评论

立即
投稿
返回
顶部