/** * Handle the timeout of a previous lock mapped to this key */ protected void handleLockExpiry(Object key, Lockable lock) { long ts = region.nextTimestamp() + region.getTimeout(); // create new lock that times out immediately Lock newLock = new Lock(ts, uuid, nextLockId.getAndIncrement(), null); newLock.unlock(ts); region.put(key, newLock); }
/** * Handle the timeout of a previous lock mapped to this key */ protected void handleLockExpiry(SharedSessionContractImplementor session, Object key, Lockable lock) { long ts = region.nextTimestamp() + region.getTimeout(); // create new lock that times out immediately Lock newLock = new Lock(ts, uuid, nextLockId.getAndIncrement(), null); newLock.unlock(ts); region.put(session, key, newLock); }
/** * Handle the timeout of a previous lock mapped to this key */ protected void handleLockExpiry(SessionImplementor session, Object key, Lockable lock) { long ts = region.nextTimestamp() + region.getTimeout(); // create new lock that times out immediately Lock newLock = new Lock(ts, uuid, nextLockId.getAndIncrement(), null); newLock.unlock(ts); region.put(session, key, newLock); }
@Override public SoftLock lockItem(SharedSessionContractImplementor session, Object key, Object version) throws CacheException { RLock writeLock = mapCache.getReadWriteLock(key).writeLock(); writeLock.lock(); try { Lockable item = (Lockable) region.get(session, key); long timeout = region.nextTimestamp() + region.getTimeout(); Lock lock; if (item == null) { lock = new Lock(timeout, uuid, nextLockId.getAndIncrement(), version); } else { lock = item.lock(timeout, uuid, nextLockId.getAndIncrement()); } region.put(session, key, lock); return lock; } finally { writeLock.unlock(); } }
@Override public SoftLock lockItem(SessionImplementor session, Object key, Object version) throws CacheException { RLock writeLock = mapCache.getReadWriteLock(key).writeLock(); writeLock.lock(); try { Lockable item = (Lockable) region.get(session, key); long timeout = region.nextTimestamp() + region.getTimeout(); Lock lock; if (item == null) { lock = new Lock(timeout, uuid, nextLockId.getAndIncrement(), version); } else { lock = item.lock(timeout, uuid, nextLockId.getAndIncrement()); } region.put(session, key, lock); return lock; } finally { writeLock.unlock(); } }
@Override public SoftLock lockItem(Object key, Object version) throws CacheException { RLock writeLock = mapCache.getReadWriteLock(key).writeLock(); writeLock.lock(); try { Lockable item = (Lockable) region.get( key ); long timeout = region.nextTimestamp() + region.getTimeout(); Lock lock; if (item == null) { lock = new Lock(timeout, uuid, nextLockId.getAndIncrement(), version); } else { lock = item.lock(timeout, uuid, nextLockId.getAndIncrement()); } region.put( key, lock ); return lock; } finally { writeLock.unlock(); } }