首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用hazelcast锁

如何使用hazelcast锁
EN

Stack Overflow用户
提问于 2015-10-02 00:29:12
回答 1查看 11.3K关注 0票数 5

我必须升级一个应用程序,这是使用一个旧版本的hazelcast到较新的版本之一。有一些hazelcast锁功能已经被弃用,并从API中完全删除。特别是,旧的锁功能是这样工作的:

代码语言:javascript
复制
Hazecast.getLock(myString);

getLock函数是Hazelcast上的静态方法。现在,它将被替换为以下内容:

代码语言:javascript
复制
hazelcastInstance.getLock(myString);

...where锁来自集群中的一个实例。

我的问题是,我可以使用hazelcast集群中的任何一个实例来获取锁吗?如果是这样的话,这会锁定所有实例吗?

EN

回答 1

Stack Overflow用户

发布于 2015-10-04 17:25:29

Q1:可以,您可以使用hazelcast集群中的任意一个实例获取锁(ILock)。

您可以将hazelcast框架中的ILock视为java.util.concurrent.locks.Lock的分布式实现。有关详细信息,请参阅

http://docs.hazelcast.org/docs/3.5/javadoc/com/hazelcast/core/ILock.html

Q2:如果使用ILock锁定临界区,那么在给定的时间点,整个集群中只有一个线程会执行受保护的临界区。因此,一旦其中一个节点中的Thread1调用了lock()方法,其他线程(也在其他节点中)将一直等待,直到锁被释放。

示例代码:

代码语言:javascript
复制
HazelcastInstance hazelcastInstance = Hazelcast.newHazelcastInstance();
Lock testLock = hazelcastInstance.getLock( "testLock" );
testLock.lock();
try 
{
   // critical section code.
} 
finally 
{
   testLock.unlock();
}
票数 8
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/32892497

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档