Redis整合Lua

一: script命令

可以使用script命令将对lua脚本进行操作

  1. script load

用于将lua脚本加载到redis中

命令: redis-cli -h ip -p 端口 -a 密码 script load "$(cat, lua脚本.lua)"

执行完上面这条命令后, 会返回一个sha码

可以通过这个 sha码直接在 redis客户端中执行脚本(evalsha 命令)

  1. script exists

用于检查 lua文件是否存在redis(使用 上一步返回的 sha码)

命令 : redis-cli -h ip -p 端口 -a 密码 script exists sha码

sha码可以多个, 返回1 则证明存在

  1. script flush

用于将redis中的lua文件清空

命令: redis-cli -h ip -p 端口 -a 密码 script flush

  1. script kill

用于杀掉正在执行的lua脚本, 因为有可能脚本执行时间过长

命令: redis-cli -h ip -p 端口 -a 密码 script kill

二:redis 执行 lua脚本
  1. eval 命令

命令格式为: eval script numkeys key [key ...] arg [arg ...]

命令解释:

script 为 lua脚本, 使用 '' 括起来. 在lua脚本中, 如果想获取参数, 使用 KEYS[index] 跟 ARGV[index]。

number 参数为指定 后面key值的个数. key跟arg都可以写多个, key跟arg之间的区分其实就是使用了number 这个值, 例如 number 为2 , 在number后面跟了 1 2 3 这三个参数 , 那么1 2 则是key,使用KEYS[1] KEYS[2] 可以获取 1 2 这两个参数。3 则是arg参数,使用ARGV[1] 获取这个 3 参数。

例子: eval 'return "key1 = " .. KEYS[1] .. ", arg1 = " .. ARGV[1] ' 1 key1 argv1
  
执行结果为 : "key1 = key1, arg1 = argv1"

  1. evalsha命令

命令格式为 evalsha sha1 numkeys key [key ...] arg [arg ...]

sha1为 script load命令加载lua脚本之后返回的 数据, 后面的跟eval数据一样

  1. 使用redisson执行lua脚本

script.eval(RScript.Mode.READ_WRITE, INCR_LONG_TTL_SHA,
                    RScript.ReturnType.VALUE, Collections.singletonList(key), ttl);

注意: 如果使用redisson执行lua脚本, 在创建Redisson客服端时, Config 需要加上这个配置config.setCodec(new StringCodec()); 否则会报错

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
RedisLua脚本是一种在Redis执行操作的脚本语言。它允许用户通过Lua脚本执行一系列的Redis操作,包括读取、写入和删除数据等。RedisLua脚本具有以下特点: 1. 原子性:RedisLua脚本执行过程中是原子的,它们要么全部执行成功,要么全部不执行。 2. 可重用性:Lua脚本可以被缓存和重复使用,提高执行效率。 3. 灵活性:Lua脚本支持逻辑控制语句、循环和函数等高级特性,可以实现复杂的业务逻辑。 4. 安全性:Lua脚本可以通过Redis的安全机制进行权限控制,确保脚本执行安全。 5. 扩展性:RedisLua脚本可以通过调用Redis提供的API扩展其功能。 RedisLua脚本执行流程包括加载脚本、编译脚本执行脚本三个步骤。在加载脚本阶段,Redis会将脚本加载到内存中,并对其进行缓存,以提高执行效率。在编译脚本阶段,Redis会对脚本进行语法检查和编译。在执行脚本阶段,Redis会按照预定的执行流程执行脚本中的命令,并返回执行结果。 RedisLua脚本在实际应用中有许多场景,包括但不限于: 1. 原子性操作:通过Lua脚本可以实现多个Redis操作的原子性,例如加锁、解锁、事务操作等。 2. 复杂数据处理:通过Lua脚本可以对Redis中的数据进行复杂的处理和计算,例如排序、过滤、聚合等。 3. 分布式锁:通过Lua脚本可以实现分布式锁,保证多个客户端之间的数据的一致性和原子性。 4. 实时计算:通过Lua脚本可以进行实时计算,例如统计、推荐算法等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值