经过lua脚原本运行redis命令主要体如今批量执行和跨语言方面,咱们能够经过redis.call()函数来执行lua脚本,下面介绍几个lua里的参数redis
eval lua-script key-num [key1 key2 key3 ....] [value1 value2 value3 ....]
在redis里添加一个foo,值是lind函数
eval "return redis.call('set',KEYS[1],ARGV[1])" 1 foo value
下面这个实例是实现分布锁的lua脚本lua
local lockClientId = redis.call('GET', KEYS[1])\n" + "if lockClientId == ARGV[1] then\n" + " redis.call('PEXPIRE', KEYS[1], ARGV[2])\n" + " return true\n" + "elseif not lockClientId then\n" + " redis.call('SET', KEYS[1], ARGV[1], 'PX', ARGV[2])\n" + " return true\n" + "end\n" + "return false"
这个脚本与开发语言没有关系。code