※ Redis分布式锁的实现,主要就是基于“加锁、释放锁、防止出现并发”三点来展开的。网上也有很多例子,但都没有实现守护线程,我在这里将守护线程的实现整合进去,供大家参考。
在《Redis实现分布式锁的思路》中我们讲了Redis分布式锁实现的思路,没看过的童鞋可以先去看一下,因为这里的实现就是基于设计思路展开的。
实现Redis分布式锁,我们需要考虑
-
加锁,使用Redis 2.6.12以上版本提供的多参数set命令。
-
释放锁,使用del命令,但需要注意在释放锁之前判断是否是自己加的锁,不要把其他线程加的锁给删除了,具体原因《Redis实现分布式锁的思路》中有详细说明。另外为了保证判断和释放操作保证原子性,此处我们使用Lua脚本实现。
-
防止出现并发,具体原因也在《Redis实现分布式锁的思路》中有详细说明,我们让获得锁的线程开启一个守护线程,给快要超时的线程续命。
代码
> pom文件
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<gro