代码拉取完成,页面将自动刷新
基于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();
<dependency>
<groupId>org.springframework.data</groupId>
<artifactId>spring-data-redis</artifactId>
<version>${spring.boot.version}</version>
</dependency>
@SpringBootApplication
@EnableRedisLock
public class WebApplication {
public static void main(String[] args) {
SpringApplication.run(WebApplication.class, args);
}
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。