当前位置:网站首页>Redisson 分布式锁
Redisson 分布式锁
2022-08-09 23:33:00 【川流不息的车呀】
@Service
@Slf4j
public class RedissonUtils {
@Autowired
private RedissonClient redissonClient;
public RLock lock(String s, int seconds) {
RLock rlock = redissonClient.getLock(s);
rlock.lock(seconds, TimeUnit.SECONDS);
return rlock;
}
}
Redis 版本比较高的,连接redis地址要加redis://,否则连接会报错
@Configuration
@EnableConfigurationProperties(RedisProperties.class)
public class RedissonConfiguration {
@Autowired
private RedisProperties redisProperties;
@Bean
public RedissonClient redissonClient() {
Config config = new Config();
String redissonAddr = "redis://" + redisProperties.getHost() + ":" + redisProperties.getPort();
config.useSingleServer().setAddress(redissonAddr);
config.useSingleServer().setDatabase(redisProperties.getDatabase());
return Redisson.create(config);
}
}配置文件获取redis配置参数:
@Component
@ConfigurationProperties(prefix = "spring.redis")
@Data
public class RedisProperties {
private String host;
private Integer port;
private Integer database;
}
具体使用如下:
首先unlock最好写在finally里面,不管异常情况,最终都会执行,防止异常情况下,锁没有及时删除的情况(虽然设置过期时间,如果过期时间比较长,下次调用会获取不到锁)
if (locked.isLocked() && locked.isHeldByCurrentThread())
锁过期时间短,已经删除的情况下使用。否则报错:java.lang.IllegalMonitorStateException: attempt to unlock lock, not locked by current thread by node
@Override
public void setUpShop(setUpRequest request){
RLock locked = null;
try {
String key = "设置的key";
locked = redissonUtils.lock(key, 1);
if (locked != null) {
//处理业务
}
} finally {
if (locked != null) {
//判断要解锁的key是否已被锁定;判断要解锁的key是否被当前线程持有
if (locked.isLocked() && locked.isHeldByCurrentThread()) {
locked.unlock();
}
}
}
}边栏推荐
- 拒绝“重复造轮子”,百度EasyDL让你玩转AI定制开发
- Fury:一个基于JIT动态编译的高性能多语言原生序列化框架
- 【C语言】通讯录《静态内存版本》
- AirFlow介绍
- 蔚来杯2022牛客暑期多校训练营7 CFGJ
- JVM Memory and Garbage Collection - 10. Direct Memory
- KingbaseGIS Jin Cang database using manual (6.3. Geometric object creation function)
- 【集训DAY5】堆箱子【数学】
- Project (7) - PolarSeg point cloud semantic segmentation
- 拼多多店铺运营不得不知的留个运营小知识
猜你喜欢
随机推荐
Leetcode80. 删除有序数组中的重复项 II
【SSL集训DAY2】Sequence【数学】
[SUCTF 2019]CheckIn (.htaccess和.user.ini)
构建平衡二叉树「建议收藏」
nfs配置
Tensor flow 踩坑记
NTP SERVICE TASK 在GWserver配置、启用NTP服务,为当前环境提供时钟同步服务,Client主机可以从该服务器同步时间。
framework源码读后感
服务发现@EnableDiscoveryClient
Service Discovery @EnableDiscoveryClient
Description of AirFlow
Redis-基本介绍/linux下环境配置/配置文件
ES6 从入门到精通 # 14:迭代器 Iterator 的用法
聚焦热点 | ISC 2022软件供应链安全治理与运营论坛圆满落幕
程序员从佩洛西窜访事件中可以学到什么?
Fury:一个基于JIT动态编译的高性能多语言原生序列化框架
第十五章 mysql存储过程与存储函数课后练习
【集训DAY4】询问【Hash】
南大通用数据库-Gbase-8a-学习-04-部署分布式集群
JVM内存和垃圾回收-10.直接内存








