1.? 依賴引入:
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
<version>2.9.0</version>
</dependency>
2.? application.yml 配置 Redis連接:
spring:
redis:
host: 172.19.125.149
password: 123456
port:6379
3. 正確代碼:
public class RedisTool {
private static final StringLOCK_SUCCESS ="OK";
private static final StringSET_IF_NOT_EXIST ="NX";
private static final StringSET_WITH_EXPIRE_TIME ="PX";
/**
? ? * 嘗試獲取分布式鎖
? ? * @param jedis Redis客戶端
? ? * @param lockKey 鎖
? ? * @param requestId 請(qǐng)求標(biāo)識(shí)
? ? * @param expireTime 超期時(shí)間
? ? * @return 是否獲取成功
? ? */
? ? public static boolean tryGetDistributedLock(Jedis jedis, String lockKey, String requestId,int expireTime) {
String result = jedis.set(lockKey, requestId,SET_IF_NOT_EXIST,SET_WITH_EXPIRE_TIME, expireTime);
if (LOCK_SUCCESS.equals(result)) {
return true;
}
return false;
}
}
代碼相關(guān)說明:
可以看到蛮粮,我們加鎖就一行代碼:jedis.set(String?key,?String?value,?String?nxxx,?String?expx,?int?time)然想,這個(gè)set()方法一共有五個(gè)形參:
第一個(gè)為key又沾,我們使用key來當(dāng)鎖,因?yàn)閗ey是唯一的杖刷。
第二個(gè)為value滑燃,我們傳的是requestId,很多童鞋可能不明白典予,有key作為鎖不就夠了嗎瘤袖,為什么還要用到value?原因就是我們?cè)谏厦嬷v到可靠性時(shí)艾扮,分布式鎖要滿足第四個(gè)條件解鈴還須系鈴人泡嘴,通過給value賦值為requestId逆济,我們就知道這把鎖是哪個(gè)請(qǐng)求加的了,在解鎖的時(shí)候就可以有依據(jù)抛虫。requestId可以使用UUID.randomUUID().toString()方法生成莱褒。
第三個(gè)為nxxx涎劈,這個(gè)參數(shù)我們填的是NX蛛枚,意思是SET?IF?NOT?EXIST,即當(dāng)key不存在時(shí)蹦浦,我們進(jìn)行set操作盲镶;若key已經(jīng)存在,則不做任何操作枫吧;
第四個(gè)為expx九杂,這個(gè)參數(shù)我們傳的是PX颁湖,意思是我們要給這個(gè)key加一個(gè)過期的設(shè)置甥捺,具體時(shí)間由第五個(gè)參數(shù)決定镰禾。
第五個(gè)為time羡微,與第四個(gè)參數(shù)相呼應(yīng)惶我,代表key的過期時(shí)間绸贡。
總的來說毅哗,執(zhí)行上面的set()方法就只會(huì)導(dǎo)致兩種結(jié)果:
1.?當(dāng)前沒有鎖(key不存在)听怕,那么就進(jìn)行加鎖操作,并對(duì)鎖設(shè)置個(gè)有效期虑绵,同時(shí)value表示加鎖的客戶端尿瞭。
2.?已有鎖存在,不做任何操作翅睛。