前言
但单机环境,锁的实现基本上是java的JUC
框架和synchronized
volatile
等关键字。整个JUC
框架包含了基本的抽象类(AQS)和锁的实现类(ReentrantLock)以及并发工具类(CountDownLatch、CyclicBarrier和Semaphore等),这些都为日常开发中对于过程同步问题提供了不少的便利。在分布式系统中,有些过程也需要同步,然后串行执行。那么有没有好用的框架可以提供这种便利性呢?答案是有的,那就是spring-integration
的spring-integration-redis
实现,里面包含了分布式锁的实现类RedisLock
。
依赖
implementation 'org.springframework.boot:spring-boot-starter-integration'
implementation 'org.springframework.integration:spring-integration-redis'
RedisLockRegistry
添加了依赖之后,就需要传入基本的配置,创建一个RedisLockRegistry
对象,后续从RedisLockRegistry
对象中obtain
出RedisLock
对象。
@Bean
public RedisLockRegistry redisLockRegistry(RedisConnectionFactory redisConnectionFactory) {
return new RedisLockRegistry(redisConnectionFactory, "registerKey",3600000);
}
从registry中获取锁
Lock lock = redisLockRegistry.obtain(KEY);
RedisLock
由于RedisLock
实现了java.util.concurrent.locks.Lock
接口,所以它是一个可轮询的锁
、可定时的锁
、可中断的锁
。可以和ReentrantLock
一样来应用锁机制。