赞
踩
Redisson是一个在Redis的基础上实现的Java驻内存数据网格(In-Memory Data Grid)。它不仅提供了一系列的分布式的Java常用对象,还提供了许多分布式服务。其中包括(BitSet, Set, Multimap, SortedSet, Map, List, Queue, BlockingQueue, Deque, BlockingDeque, Semaphore, Lock, AtomicLong, CountDownLatch, Publish / Subscribe, Bloom filter, Remote service, Spring cache, Executor service, Live Object service, Scheduler service) Redisson提供了使用Redis的最简单和最便捷的方法。Redisson的宗旨是促进使用者对Redis的关注分离(Separation of Concern),从而让使用者能够将精力更集中地放在处理业务逻辑上。
对于分布式锁的要求
互斥性:分布式锁需要保证在不同节点的不同线程的互斥。这是最根本的。
可重入性:同一个节点上的同一个线程如果获取了锁之后也可以再次获取这个锁。
锁超时:和本地锁一样支持锁超时,防止死锁。
高可用:加锁和解锁需要高效,同时也需要保证高可用防止分布式锁失效,可以增加降级。
支持阻塞和非阻塞:和 ReentrantLock 一样支持 lock 和 trylock 以及 tryLock(long timeOut)。
支持公平锁和非公平锁(可选):公平锁的意思是按照请求加锁的顺序获得锁,非公平锁就相反是无序的。这个一般来说实现的比较少。
tryLock()方法是有返回值的,它表示用来尝试获取锁,如果获取成功,则返回true,如果获取失败(即锁已被其他线程获取),则返回false,这个方法无论如何都会立即返回。在拿不到锁时不会一直在那等待。
- RLock lock = redisson.getLock("anyLock");
- // 最常见的使用方法
- lock.lock();
- ...
- lock.unlock()
- // 加锁以后10秒钟自动解锁
- // 无需调用unlock方法手动解锁
- lock.lock(10, TimeUnit.SECONDS);
-
- // 尝试加锁,最多等待100秒,上锁以后10秒自动解锁
- boolean res = lock.tryLock(100, 10, TimeUnit.SECONDS);
- ...
- lock.unlock();
公平锁
- RLock fairLock = redisson.getFairLock("anyLock");
- // 最常见的使用方法
- fairLock.lock();
- // 10秒钟以后自动解锁
- // 无需调用unlock方法手动解锁
- fairLock.lock(10, TimeUnit.SECONDS);
-
- // 尝试加锁,最多等待100秒,上锁以后10秒自动解锁
- boolean res &#
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。