Distributed Lock Service
Which distributed lock service would you use?
Requirements are:
- A mutual exclusion (lock) that can be seen from different processes/machines
- lock...release semantics
- Automatic lock release after a certain timeout - if lock holder dies, it will automatically be freed after X seconds
- Java implementation
- Nice to have: .Net implementation
- If it's free: Deadlock detection / mitigation
- Easy deployment, see note below.
I'm not interested in answers like "it can be done over a database", or "it can be done over JavaSpaces" - I know. I'm interested in a ready, out-of-the-box, proven implementation.
Teracotta, including the Open Source edition, has distributed locking semantics by using either synchronized
or the java.util.concurrent.ReentrantReadWriteLock
- the latter apparently fitting your requirements.
Update
Since the question now added the requirement of 'mixing' with GigaSpaces, I'm going to say don't mix them. It's just going to add more complexity to your technological stack, and the effort of:
- integrating, in terms of both code and infrastructure;
- managing synchronisation between them;
- learning/tuning/debugging Teracotta.
will be better spent creating or implementing a locking solution based on GigaSpaces.
A newer kid on the block is hazelcast. I've been playing with it and it is amazingly simple to use and configure.
As far as I can see there shouldn't be any conflict between Gigaspaces and hazelcast as hazelcast doesn't have any dependencies i.e. no jgroups.jar etc
Hazelcast:
- A mutual exclusion (lock), yep implementation of
java.util.concurrency.locks.Lock
- Automatic lock release after a certain timeout, yep all locks are released if a member leaves the cluster
- Java implementation, yep
- Nice to have: .Net implementation, nope is a pure java solution, might be possible to port to j#
- If it's free: Deadlock detection / mitigation, nope no effort is made my Hazelcast to handle this
- Easy deployment, it's a single jar with a single config file, deployed as part of your application, no additional processes are required
Check out Apache's Zookeeper (A Hadoop sub-project) - it offers distributed synchronization. The documentation isn't great, but what there is makes it look an interesting product - checkout the recipes for ideas on how to use Zookeeper.
It is lower-level than you'd probably want and it does require additional deployment as it recommends dedicated servers.
You can model different locking strategies and it does offer a solution for a lock holder dying (ephemeral nodes).
I recommend to use Redisson it's a Redis based on In-Memory Data Grid. It implements familiar Java data structures including distributed java.util.Lock
and java.util.concurrent.ReentrantReadWriteLock
objects. Including ability to setup leaseTime. Lock
usage example:
Redisson redisson = Redisson.create(config);
Lock lock = redisson.getLock("anyLock");
try {
// unlock automatically after 10 seconds of hold
lock.lock(10, TimeUnit.SECONDS);
} finally {
lock.unlock();
}
...
redisson.shutdown();
Supports cloud vendors like Azure and AWS.
ZooKeeper became a de facto standard in distributed locking with the help of Apache Curator framework. Check out the locks in recipes for more information.
Oracle Coherence, which is very stable and mature, includes mutual exclusion support:
cache.lock(key, -1);
try {
// .. add your critical code here
} finally {
cache.unlock(key);
}
Locks survive server failures, rolling re-starts, etc.
For the sake of full disclosure, I work at Oracle. The opinions and views expressed in this post are my own, and do not necessarily reflect the opinions or views of my employer.
ReferenceURL : https://stackoverflow.com/questions/1059580/distributed-lock-service
'programing' 카테고리의 다른 글
"인덱싱 된 콘텐츠에서 이동할 수 없음"이란 무엇을 의미합니까? (0) | 2021.01.15 |
---|---|
신속한 성능 : map () 및 reduce () 대 for 루프 (0) | 2021.01.15 |
C 전처리 기가 먼저 주석을 제거하거나 매크로를 확장합니까? (0) | 2021.01.15 |
100 % CPU를 사용하는 W3WP.EXE-어디서부터 시작해야합니까? (0) | 2021.01.15 |
SQL Server에서 행 수준 잠금을 강제 할 수 있습니까? (0) | 2021.01.15 |