本文整理汇总了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;
}