lock 为 java 设计的分布式锁,开箱即用,纵享丝滑。
开源地址:https://github.com/houbb/lock
开箱即用,支持注解式和过程式调用
基于 redis 的分布式锁
内置支持多种 redis 的整合方式
渐进式设计,可独立于 spring 使用
整合 spring
整合 spring-boot
jdk1.7+
maven 3.x+
com.github.houbb lock-core 1.3.0
基于本地 redis 的测试案例。
public void helloTest() {ILock lock = LockBs.newInstance();String key = "ddd";try {// 加锁lock.tryLock(key);System.out.println("业务处理");} catch (Exception e) {throw new RuntimeException(e);} finally {// 释放锁lock.unlock(key);}
}
为了便于拓展,LockBs 的配置支持自定义:
LockBs.newInstance().id(Ids.uuid32()) //id 生成策略.cache(JedisRedisServiceFactory.pooled("127.0.0.1", 6379)) //缓存策略.lockSupport(new RedisLockSupport()) // 锁实现策略.lockKeyFormat(new LockKeyFormat()) // 针对 key 的格式化处理策略.lockReleaseFailHandler(new LockReleaseFailHandler()) //释放锁失败处理;
com.github.houbb lock-spring 1.3.0
@EnableLock
启用分布式锁。
@EnableRedisConfig
启用 redis 的默认配置。
@Configurable
@ComponentScan(basePackages = "com.github.houbb.lock.test.service")
@EnableLock
@EnableRedisConfig
public class SpringConfig {
}
EnableLock
注解说明,和引导类对应:
public @interface EnableLock {/*** 唯一标识生成策略* @return 结果*/String id() default "lockId";/*** 缓存实现策略 bean 名称** 默认引入 redis-config 中的配置** @return 实现*/String cache() default "springRedisService";/*** 加锁 key 格式化策略* @return 策略*/String lockKeyFormat() default "lockKeyFormat";/*** 锁释放失败处理类* @return 结果*/String lockReleaseFailHandler() default "lockReleaseFailHandler";}
其中 springRedisService
使用的是 redis-config 中的实现。
对应注解 @EnableRedisConfig
,redis 的配置信息如下:
配置 | 说明 | 默认值 |
---|---|---|
redis.address | redis 地址 | 127.0.0.1 |
redis.port | redis 端口 | 6379 |
redis.password | redis 密码 |
我们可以直接 LockBs
的引导类,这种适合一些更加灵活的场景。
@ContextConfiguration(classes = SpringConfig.class)
@RunWith(SpringJUnit4ClassRunner.class)
public class SpringServiceRawTest {@Autowiredprivate UserService userService;@Autowiredprivate LockBs lockBs;@Testpublic void queryLogTest() {final String key = "name";try {lockBs.tryLock(key);final String value = userService.rawUserName(1L);} catch (Exception exception) {throw new RuntimeException(exception);} finally {lockBs.unlock(key);}}}
当然,我们可以在方法上直接指定注解 @Lock
,使用更加方便。
直接使用,AOP 切面生效即可。
@Service
public class UserService {@Lockpublic String queryUserName(Long userId) {}@Lock(value = "#user.name")public void queryUserName2(User user) {}
}
@Lock
属性说明,value 用于指定 key,支持 SPEL 表达式。
其他属性,和引导类的方法参数一一对应。
public @interface Lock {/*** 缓存的 key 策略,支持 SpEL* @return 结果*/String value() default "";/*** 时间单位* @return 单位*/TimeUnit timeUnit() default TimeUnit.SECONDS;/*** 等待锁时间* @return 等待锁时间*/long waitLockTime() default 10;/*** 业务加锁时间* @return 加锁时间*/long lockTime() default 60;}
com.github.houbb lock-springboot-starter 1.3.0
同 spring
持有锁的线程可以多次获取锁
Redis 分布式锁
java 从零实现 redis 分布式锁
cache: 手写渐进式 redis
common-cache: 通用缓存标准定义
redis-config: 兼容各种常见的 redis 配置模式
lock: 开箱即用的分布式锁
resubmit: 防重复提交
rate-limit: 限流