基于Lua脚本优化Redis分布式锁

基于Lua脚本优化Redis分布式锁

Redis提供了Lua脚本功能,在一个脚本中编写多条Redis命令,确保多条命令执行时的原子性.Lua是一种编程语言,它的基本用法可以参考网站:
[link](https:/ /www.runoob.com/lua/lua-tutorial.html/)
这里重点介绍Redis提供的调用函数,语法如下:

--执行rides命令
redis.call('命令名称','key','其他参数',...)

== 例如我们要执行set a v1,则脚本是这样的 ==

--执行rides命令
redis.call('set','a','v1')

写好脚本以后,需要用Redis命令来调用脚本,调用脚本的常见命令如下:
基于Lua脚本优化Redis分布式锁_第1张图片
例如,我们要执行==redis.call(‘set’,‘a’,‘v1’)==这个脚本,语法如下:

–调用脚本
EVAL “return redis.call(‘set’,‘a’,‘v1’)” 0

基于Lua脚本优化Redis分布式锁_第2张图片
如果参数不想写死,可以这样做
可以用参数传递方式,key类型参数会放入KEYS数组,其他参数会放入ARGV数组,在脚本中可以从KEYS和ARGV数组中获取这些参数:
在这里插入图片描述
这个脚本可以解决,并发编程下多线程误删锁问题
这里的KEYS[1],就是你设置的锁的key,ARGV[1]就是当前执行线程的标识,可以是id,name等,具体看你自己设置

if(redis.call('get',KEYS[1]) == ARGV[1]) then
    --释放锁 del key
    return redis.call('del',KEYS[1])
end
return 0

你可能感兴趣的:(java,redis)