- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我已经在Java应用程序中创建了单例redisson实例,用于与Redis服务器进行通信。
现在,使用此重做实例,我将获得一个锁,该锁在完成某些任务后将释放。但是在调用unlock方法之后,我仍然看到redis具有锁定,而其他线程无法获取该锁定。
以下是我正在使用的代码段:
class RedisInstance
{
static RedisInstance ins;
private RedisInstance()
{
ins = new RedisInstance();
}
public static RedisInstance getInstance()
{
return ins;
}
//Acquire the lock:
public boolean acquireLock(String lockKey)
{
RLock redisLock = getRedisClient().getLock(lockKey);
boolean isLockFree;
try
{
isLockFree = redisLock.tryLock(lockAcquistionTimeLimit, TimeUnit.SECONDS);
if(isLockFree)
{
redisLock.lock();
logger.info("lock acquired for: {}", lockKey);
return true;
}
}
catch (InterruptedException e)
{
logger.error("Got exception {} in acquiring Redis Lock for: {}" , e, lockKey);
}
return false;
}
//Release the lock:
public void unlock(String lockKey)
{
RLock redisLock = getRedisClient().getLock(lockKey);
redisLock.unlock();
logger.debug("IS redis locked "+redisLock.isLocked());
logger.info("lock released for: {}", lockKey);
}
}
class A
{
RedisIns ins = RedisInstance.getInstance();
public void run()
{
if(ins.acquireLock(lockKey))
{
try
{
//do some processing takes less than a second
}
catch(Exception e)
{
}
finally
{
ins.unlock(lockKey);
}
}
}
//In my main method:
public static void main(String args[])
{
A a = new A();
A b = new A();
Thread t1 = new Thread(a);
Thread t2 = new Thread(b);
t1.start();
Thread.sleep(5000); //just to mock, lets say t1 finishes before t2 starts
t2.start();
}
}
在t1调用
ins.unlock(lockKey);
之后,日志
logger.debug("IS redis locked "+redisLock.isLocked());
说:true,并且
t2
无法获取锁。
redisLock.unlock();
替换为
redisLock.forceUnlock();
,那么一切都会按预期进行。
最佳答案
tryLock如果获取了锁,则返回true。因此,在此之后不需要调用锁,我认为这可能是导致您出现问题的原因。该实现可能期望锁定/解锁的数量为偶数,并且在这种情况下,您的锁定要比解锁多。
关于java - Redis的Redisson的API方法.unlock()未释放锁,尝试从同一实例进行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63839691/
给定一个主节点和多个启用 Sentinels 的副本节点,Redisson 配置为仅从副本节点读取,并启用循环负载均衡器和重试。在 Redisson 重试尝试的情况下,它会再次调用负载均衡器以确定新的
我正在使用 RMap 来存储 RLock。当我尝试从此映射中获取(key)时,它返回给我一个 RedissonReference 而不是 RLock 的实例。我无法将其转换为 RLock。我正在使用以
在解决 LiveObject 引发的异常时遇到问题,我尝试根据 Redisson 测试用例重现有问题的行为。 我重现问题的最少代码是这个测试用例(主要灵感来自 RedissonLiveObjectSe
什么是分布式锁?实现分布式锁的常用三种方式 在很多场景中,我们为了保证数据的最终一致性,需要很多的技术方案来支持,比如分布式事务、分布式锁等。那具体什么是分布式锁,分布式锁应用在哪些业务场景、如何来实
前言 默认的加锁逻辑是非公平的。 在加锁失败时,线程会进入 while 循环,一直尝试获得锁,这时候是多线程进行竞争。就是说谁抢到就是谁的。 Redisson 提供了公平锁机制,使用方式如
我需要保留添加到 Redis 中的 SET 的元素的顺序。为了做到这一点,我将 RSortedSet 与自定义比较器一起使用。 这里面临的问题是,与 RSetCache 不同,我无法使该 SET 中的
我正在为 redission 客户端编写一个适配器以在我们的应用程序中使用,我不确定在 Finalize block 中关闭客户端是否是一个好的设计。下面是代码。请告诉我 private static
我有一个 java 对象(ComponentType.java),我需要将其存储在 Redis 中。我使用 Redisson 作为客户端库。该对象有一个实例变量(ComponentType),该变量只
如果 key 大小非常大,是否有一种方法可以迭代扫描 key 而不会使 Redis 集群过载? Redis 原生支持这一点。 如果上述可行,那么我可以控制每次往返返回多少个 key 吗? 最佳答案 我
我正在为我的 Java 应用程序使用 Redisson。在他们的文档中说 redisson 在任何 redis 节点上创建对象。这是什么意思? 例如: If I do RSet l_campaign_
我正在使用单服务器模式配置redis服务器和端口,我在这里遗漏了什么吗? Config config = new Config(); config.useSingleServer().setAddre
我试图引用文档,但我仍然不清楚 CacheConfig 中 ttl 和 maxIdleTime 之间的区别。 Redisson 中的类。 任何人都可以解释一下吗? 最佳答案 maxIdleTime
我现在正在学习Redisson,我有一个例子如下: public class TestRedisson { public static void main(String[] args) {
Redisson的 getLock() 方法是否适合分布式用例,它与 getRedLock() 相比如何? Redisson(3.11.x)有几种实例化锁的方法: RedissonClient.get
在我当前的项目中,Redisson 用于使用 JsonJacksonCodec 缓存许多不同的类。这按预期工作,但我希望仅使用 MsgPack 序列化某个包中的类,而让其余部分按原样序列化。 根据我的
我们想使用redisson-hibernate项目https://github.com/redisson/redisson/tree/master/redisson-hibernate支持redis二
baeldung列出了 Redisson 作为 Redis 客户端的几个好处。所以我决定使用它。出于 POC 目的,我使用单节点实例,可能稍后会切换到其他实例。检查Redisson connectio
如果我想在 Redisson 中设置存储桶,是否需要通过合并 Redisson.getLock() 来防止竞争条件?或者 RBucket.set() 在内部执行此操作? 一般来说,除了应用程序需求之外
我正在使用 Redisson 库来管理 redis 中的数据,并具有以下 POJO(此处保留 get/set/constructor)。 @REntity Class A { @RId St
redisson 是否有合适的文档或最佳实践? 我正在使用 .getBlockingQueue(),它允许 offer() 和 put(),但我不知道是什么队列的容量是。我想将它设置为根据需要扩展,但
我是一名优秀的程序员,十分优秀!