作者:微信小助手
发布时间:2020-03-04T18:51:15
Redis分布式锁原理概述
Spring Boot集成使用方式
<!-- spring integration -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-integration</artifactId>
</dependency>
<!-- spring integration与redis结合,实现redis分布式锁 -->
<dependency>
<groupId>org.springframework.integration</groupId>
<artifactId>spring-integration-redis</artifactId>
</dependency>
目前Spring所提供的分布式锁相关的代码被迁移在Spring Integration子项目中,所以这里引入其相关依赖。
2)编写RedisLock的配置类,代码如下:
@Configuration
public class RedisLockConfiguration {
@Bean
public RedisLockRegistry redisLockRegistry(RedisConnectionFactory redisConnectionFactory) {
return new RedisLockRegistry(redisConnectionFactory, "payment");
}
}
以上配置代码加载的前提在于应用已经集成了Redis服务访问链接信息,具体Spring Boot项目集成Redis访问的方式比较简单可以参考其他资料。
3)分布式锁的具体使用方式,代码片段如下:
/**
* 引入Redis分布式锁依赖组件
*/
@Autowired
private RedisLockRegistry redisLockRegistry;
@Override
public UnifiedPayBO unifiedPay(UnifiedPayDTO unifiedPayDTO) {
...
//创建Redis分布式锁
Lock lock = redisLockRegistry.obtain(redisLockPrefix + unifiedPayDTO.getOrderId());
try {
//尝试获取锁
boolean isLock = lock.tryLock(1, TimeUnit.SECONDS);
if (isLock) {
//执行业务逻辑
...
}
} catch (InterruptedException e) {
e.printStackTrace();
} finally {
//释放分布式锁
lock.unlock();
}
...
}
上述代码为订单防重时使用Redis分布锁的示例代码,通过依赖注入RedisLockRegistry实例来实现分布式锁的相关操作,例如obtain()方法创建锁、tryLock()持有锁及unlock()释放锁等。
—————END—————