代码拉取完成,页面将自动刷新
redis-lock是基于redis实现的分布式锁,三种使用方式和SpEL的支持,一个注解搞定,让分布式锁不再繁琐
// 按全局超时时间获取分布式锁
RedisLock redisLock = this.lockFactory.get(key);
// 按自定义超时时间获取分布式锁
RedisLock redisLock = this.lockFactory.get(key, 5, TimeUnit.MINUTES);
<dependency>
<groupId>life.itzn</groupId>
<artifactId>redis-lock</artifactId>
<version>1.0.0</version>
</dependency>
spring:
redis:
host: 127.0.0.1
port: 6379
lock:
prefix: lock 全局锁名前缀,默认为:lock
time: 60 全局超时时间,默认为:60
unit: SECONDS 全局超时单位,默认为:秒
@Autowired
private LockFactory lockFactory;
@GetMapping("/{key}")
public String lock1(@PathVariable String key) {
RedisLock redisLock = this.lockFactory.get(key);
try {
if (!redisLock.tryLock(5, TimeUnit.SECONDS)) {
return "按自定义锁时间获取锁失败:" + key;
}
} finally {
redisLock.unlock();
}
return "获取锁成功:" + key;
}
@Autowired
private LockFactory lockFactory;
@GetMapping("/{key}")
public String lock2(@PathVariable String key) {
try (RedisLock redisLock = this.lockFactory.get(key)) {
if (!redisLock.tryLock(5, TimeUnit.SECONDS)) {
return "获取锁失败:" + key;
}
}
return "获取锁成功:" + key;
}
// code:用于区分业务,key:用于从参数中获取KEY
@MethodLock(code = "account", key = "#key")
@GetMapping("/{key}")
public String lock3(@PathVariable String key) {
// 如果获取锁失败,会抛出RuntimeException
return "获取锁成功,key:" + key;
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。