目的:保证同一个线程可以多次获取同一把锁
解决思路:在锁的 value 中额外保存当前线程获取锁的次数,每次获取锁 +1、释放锁 -1,当次数为 0 时才真正删除 key。
采用hash结构来存储锁信息,如图:
流程如下:
注意:
所有的判断和操作都需要使用Lua脚本来保证原子性
每次获取和释放锁时要重置锁的有效期。
获取锁的Lua脚本:
释放锁的Lua脚本: