Hazelcast - 为什么 IMap.remove(key) 被阻止?需要强行移除

Hazelcast - why IMap.remove(key) is blocked? Need forceRemove

我想在管理操作时强制从映射中删除一个键。试图删除的线程不是放置 ...

线程卡住如下..:[=​​12=]

Thread [xxxx] (Suspended)   
    waiting for: InvocationFuture<E>  (id=1746) 
    Object.wait(long, int) line: not available [native method]  
    InvocationFuture<E>(Object).wait(long) line: 201    
    InvocationFuture<E>.pollResponse(long) line: 300    
    InvocationFuture<E>.waitForResponse(long, TimeUnit) line: 245   
    InvocationFuture<E>.get(long, TimeUnit) line: 222   
    InvocationFuture<E>.get() line: 202 
    MapProxyImpl<K,V>(MapProxySupport).invokeOperation(Data, MapOperation) line: 320    
    MapProxyImpl<K,V>(MapProxySupport).removeInternal(Data) line: 449   
    MapProxyImpl<K,V>.remove(Object) line: 188  

为什么 map.remove() 阻塞?没有办法强制从地图中删除条目吗?

谢谢

map.remove 是锁感知的,这意味着它将等待直到锁被释放。这是方法调用可能无法立即完成的原因之一。

所以问题:你在使用锁吗?

如果是这样,您可以执行 map.forceUnlock 然后调用 map.remove()。 不知道它是否适合您的业务用例(很难想象)。