代码拉取完成,页面将自动刷新
同步操作将从 Stan/spring-redis-distributed-lock 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
spring-redis-distributed-lock 为redisLock项目扩展而来 https://gitee.com/billion/redisLock
一个应用于springboot项目的,基于redis的分布式锁 可用于多节点项目防重复业务调用
通过方法注解开启 简单、易用
可以通过简单的注解配置达到同机器或不同机器竞争锁
@EnableLock
public class XXServiceApplication {
public static void main(String[] args) {
SpringApplication.run(XXServiceApplication.class, args);
}
}
@Lock(policy = LockPolicy.Lock, featureParams = MacAddressFeatureParam.class)
public boolean service(@LockKey int id, @LockKey String name) {
//业务代码
}
名称 | 类型 | 默认值 | 备注 |
---|---|---|---|
policy | LockPolicy | Lock | 锁策略 默认为Lock:获取锁失败立即返回;SpinLock:自旋锁,达到timeout后返回;BlockLock:持续自旋直到获取锁返回 |
keyPrex | String | 类名+方法名 | redis锁的key前缀 如果为空,则默认为类名+方法名 |
featureParams | LockFeatureParam | 无 | 特征字参数方法集,可以增加不在业务方法中的特征参数用于区分锁,防止竞争锁 可实现LockFeatureParam 扩展自定义非业务参数 |
lockTime | int | 60 | 锁持续时间,将设定在redis中用于值存在的时间 单位s |
timetOut | long | 300 | SpinLock超时时间 单位ms |
@Lock
public boolean service() {
//业务代码
}
@Lock
public boolean service(@LockKey int id) {
//业务代码
}
@Lock(featureParams = MacAddressFeatureParam.class)
public boolean service(@LockKey int id) {
//业务代码
}
@Lock(policy = LockPolicy.SpinLock, timetOut = 500L)
public boolean service(@LockKey int id) {
//业务代码
}
@Lock(policy = LockPolicy.BlockLock)
public boolean service(@LockKey int id) {
//业务代码
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。