1 Star 0 Fork 0

limbo world / redis-lock

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
贡献代码
同步代码
取消
提示: 由于 Git 不支持空文件夾,创建文件夹后会生成空的 .keep 文件
Loading...
README

redis-locked

介绍

基于Redis实现的分布式锁

使用

Redis可以开启expired\evict\delete的事件监听,帮助更好的唤醒锁;不开也可以用;

RedisLock继承自java.util.concurrent.locks.Lock,可以像使用ReentrantLock一样使用,不同的是初始化使用LockContext.createLock,并且在使用完毕后应关闭锁

// 一个虚拟机中可以存在多个LockContext
LockConfiguration configuration = LockConfiguration.builder().lockPrefix("RedisLockAA").build();
LockContext context = new LockContext(configuration, redisConnectionFactory);
// 锁从LockContext初始化
RedisLock locked = context.createLock("TestLock");
locked.locked();
locked.unlock();
// 使用后应该关闭锁,释放锁占有的redis资源
locked.close();

在SpringBoot中使用

  1. 首先在pom中引入spring-data-redis;
<dependency>
    <groupId>org.springframework.data</groupId>
    <artifactId>spring-data-redis</artifactId>
    <version>${spring.boot.version}</version>
</dependency>
  1. 在启动类上添加注解 @EnableRedisLock;
@SpringBootApplication
@EnableRedisLock
public class WebApplication {

    public static void main(String[] args) {
        SpringApplication.run(WebApplication.class, args);
    }
}
  1. 在需要加锁的方法上添加注解 @Locked,即可使使方法同步;锁定策略等参考@Locked注解属性的注释;

待实现

  1. 锁租约到期自动续约?
  2. 实现condition实现分布式多线程同步?

空文件

简介

基于Redis实现的分布式锁;支持方法注解加锁;支持SpringBoot一键开启; 展开 收起
取消

发行版

暂无发行版

贡献者

全部

近期动态

加载更多
不能加载更多了
1
https://gitee.com/LimboHome/redis-lock.git
git@gitee.com:LimboHome/redis-lock.git
LimboHome
redis-lock
redis-lock
master

搜索帮助