SpringBoot执行Lua脚本

蔚落 2023-01-07 08:54 225阅读 0赞

Lua

Lua 是一种轻量小巧的脚本语言,用标准C语言编写并以源代码形式开放, 其设计目的是为了嵌入应用程序中,从而为应用程序提供灵活的扩展和定制功能。

  • lua执行过程
    客户端把整个lua脚本发送给服务器,服务分别执行每个脚本。注:脚本执行过程不会被打断。
  • 事务和lua
    redis中lua执行不同于事务,redis中事务是基于乐观锁(watch),而lua脚本基于redis单线程执行。
    相同点:
    都有一致性、隔离性和持久性,但没有实现原子性,无论是redis事务,还是lua脚本,如果执行期间出现运行错误,之前的执行过的命令是不会回滚的。
    不同点:
    1、redis事务是基于乐观锁,lua脚本是基于redis的单线程执行命令。
    2、redis事务的执行原理就是一次命令的批量执行,而lua脚本可以加入自定义逻辑。

RedisTemplate执行lua

  1. DefaultRedisScript<String> rs = new DefaultRedisScript<>("return 'Hello Redis' ", String.class);
  2. //指定传递参数序列化方式
  3. RedisSerializer argsSerializer = redisTemplate.getDefaultSerializer();
  4. //指定返回结果序列化方式
  5. RedisSerializer<String> resultSerializer = redisTemplate.getStringSerializer();
  6. //执行Lua脚本
  7. String res = (String) redisTemplate.execute(rs, argsSerializer, resultSerializer, null);
  • 也可传递多行lua

    //注意脚本中KYS[l]和KYS[2] 的写法,它们代表客户端传递的第一个键和第二个键,

    1. //而ARGV[l]和ARGV[2]则表示客户端传递的第一个和第二个参数
    2. String lua = "redis.call ('set', KEYS[1], ARGV[1]) \n"
    3. + "redis.call ('set', KEYS[2], ARGV[2]) \n "
    4. + " local str1 = redis.call ('get', KEYS [1]) \n "
    5. + " local str2 = redis.call ('get', KEYS [2]) \n "
    6. + " if str1 == str2 then \n "
    7. + " return 1 \n "
    8. + " end \n "
    9. + " return 0 \n ";

lua中KEYSARGV值从redisTemplate.execute传递List<K> keys, Object... args参数中获得。

上面脚本需要两个KEYS和两个ARGV:

  1. redisTemplate.execute(rs, argsSerializer, resultSerializer, Arrays.asList(KYS[l], KYS[2]), ARGV[1], ARGV[1])

执行异常处理

有小伙伴有调用时候没有指定序列化方式直接:

  1. redisTemplate.execute(rs, Arrays.asList(KYS[l], KYS[2]), ARGV[1], ARGV[1])

没有指定充列化方式,返回字符串会提示:

com.fasterxml.jackson.core.JsonParseException: Unrecognized token ‘Hello’: was expecting (JSON String, Number, Array, Object or token ‘null’, ‘true’ or ‘false’)

因为redis中不是直接存储string,是数组形式,——redis原理

它无法直接序列化,所以得指定序列化方式。

发表评论

表情:
评论列表 (有 0 条评论,225人围观)

还没有评论,来说两句吧...

相关阅读

    相关 SpringBoot + Redis 执行lua脚本

    1、背景 有时候,我们需要一次性操作多个 Redis 命令,但是 这样的多个操作不具备原子性,而且 Redis 的事务也不够强大,不支持事务的回滚,还无法实现命令之间的逻

    相关 SpringBoot执行Lua脚本

    Lua Lua 是一种轻量小巧的脚本语言,用标准C语言编写并以源代码形式开放, 其设计目的是为了嵌入应用程序中,从而为应用程序提供灵活的扩展和定制功能。 lua执

    相关 redis执行Lua脚本

    Lua 是一个小巧的脚本语言。该语言的设计目的是为了嵌入应用程序中,从而为应用程序提供灵活的扩展和定制功能。 Lua脚本可以很容易的被C/C++代码调用,也可以反过来调