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()。
不知道它是否适合您的业务用例(很难想象)。
我想在管理操作时强制从映射中删除一个键。试图删除的线程不是放置 ...
线程卡住如下..:[=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()。 不知道它是否适合您的业务用例(很难想象)。