本文整理匯總了Java中redis.clients.jedis.ShardedJedis.getShard方法的典型用法代碼示例。如果您正苦於以下問題:Java ShardedJedis.getShard方法的具體用法?Java ShardedJedis.getShard怎麽用?Java ShardedJedis.getShard使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類redis.clients.jedis.ShardedJedis
的用法示例。
在下文中一共展示了ShardedJedis.getShard方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: releaseLock
import redis.clients.jedis.ShardedJedis; //導入方法依賴的package包/類
/**
* 釋放鎖
*
* @param lockName 鎖的key
* @param identifier 釋放鎖的標識
*/
public boolean releaseLock(String lockName, String identifier){
Jedis conn = null;
String lockKey = lockPrefix + lockName;
boolean retFlag = false;
ShardedJedis shardedJedis = jedisPool.getResource();
try {
conn = shardedJedis.getShard(lockKey);
while (true) {
// 監視lock,準備開始事務
conn.watch(lockKey);
// 通過前麵返回的value值判斷是不是該鎖,若是該鎖,則刪除,釋放鎖
if (identifier.equals(conn.get(lockKey))) {
Transaction transaction = conn.multi();
transaction.del(lockKey);
List<Object> results = transaction.exec();
if (results == null) {
continue;
}
retFlag = true;
}
conn.unwatch();
break;
}
} catch (JedisException e) {
LOGGER.error("releaseLock found exception", e);
} finally {
if (conn != null) {
jedisPool.returnResource(shardedJedis);
}
}
return retFlag;
}