溫馨提示×

redis如何防止死鎖

小新
313
2021-01-19 16:46:02
欄目: 云計算

redis如何防止死鎖

redis防止死鎖的方法:

1.鎖信息設置一定是會過期超時的,不允許一個線程長期占有一個鎖。

2.同一時刻只能有一個線程獲取到鎖。

代碼示例:

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;

0
亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女