Class DefaultLockRepository
java.lang.Object
org.springframework.integration.jdbc.lock.DefaultLockRepository
- All Implemented Interfaces:
Closeable,AutoCloseable,InitializingBean,LockRepository
@Repository
public class DefaultLockRepository
extends Object
implements LockRepository, InitializingBean
The default implementation of the
LockRepository based on the
table from the script presented in the org/springframework/integration/jdbc/schema-*.sql.
This repository can't be shared between different JdbcLockRegistry instances.
Otherwise it opens a possibility to break Lock contract,
where JdbcLockRegistry uses non-shared ReentrantLocks
for local synchronizations.
- Since:
- 4.3
- Author:
- Dave Syer, Artem Bilan, Glenn Renfro, Gary Russell, Alexandre Strubel, Ruslan Stelmachenko
-
Field Summary
FieldsModifier and TypeFieldDescriptionstatic final StringDefault value for the table prefix property.static final intDefault value for the time-to-live property. -
Constructor Summary
ConstructorsConstructorDescriptionDefaultLockRepository(DataSource dataSource) Constructor that initializes the client id that will be associated for all the locks persisted by the store instance to a randomUUID.DefaultLockRepository(DataSource dataSource, String id) Constructor that allows the user to specify a client id that will be associated for all the locks persisted by the store instance. -
Method Summary
Modifier and TypeMethodDescriptionbooleanvoidvoidclose()voidvoidbooleanisAcquired(String lock) booleanvoidSpecify the prefix for target data base table used from queries.voidA unique grouping identifier for all locks persisted with this store.voidsetTimeToLive(int timeToLive) Specify the time (in milliseconds) to expire dead locks.
-
Field Details
-
DEFAULT_TABLE_PREFIX
Default value for the table prefix property.- See Also:
-
DEFAULT_TTL
public static final int DEFAULT_TTLDefault value for the time-to-live property.- See Also:
-
-
Constructor Details
-
DefaultLockRepository
Constructor that initializes the client id that will be associated for all the locks persisted by the store instance to a randomUUID.- Parameters:
dataSource- theDataSourceused to maintain the lock repository.
-
DefaultLockRepository
Constructor that allows the user to specify a client id that will be associated for all the locks persisted by the store instance.- Parameters:
dataSource- theDataSourceused to maintain the lock repository.id- the client id to be associated with locks handled by the repository.- Since:
- 4.3.13
-
-
Method Details
-
setRegion
A unique grouping identifier for all locks persisted with this store. Using multiple regions allows the store to be partitioned (if necessary) for different purposes. Defaults toDEFAULT.- Parameters:
region- the region name to set
-
setPrefix
Specify the prefix for target data base table used from queries.- Parameters:
prefix- the prefix to set (default INT_).
-
setTimeToLive
public void setTimeToLive(int timeToLive) Specify the time (in milliseconds) to expire dead locks.- Parameters:
timeToLive- the time to expire dead locks.
-
afterPropertiesSet
public void afterPropertiesSet()- Specified by:
afterPropertiesSetin interfaceInitializingBean
-
close
- Specified by:
closein interfaceAutoCloseable- Specified by:
closein interfaceCloseable- Specified by:
closein interfaceLockRepository
-
delete
- Specified by:
deletein interfaceLockRepository
-
acquire
@Transactional(propagation=REQUIRES_NEW, isolation=SERIALIZABLE) public boolean acquire(String lock) - Specified by:
acquirein interfaceLockRepository
-
isAcquired
- Specified by:
isAcquiredin interfaceLockRepository
-
deleteExpired
- Specified by:
deleteExpiredin interfaceLockRepository
-
renew
- Specified by:
renewin interfaceLockRepository
-