redis执行lua脚本的实现

 更新时间:2024年10月29日 10:13:33   作者:lx18854869896  
本文主要介绍了redis执行lua脚本的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

redis EVAL命令可以执行lua脚本,redis保证脚本执行的原子性,脚本由嵌入式执行引擎(Lua 5.1解释器)执行。

1,语法

EVAL script numkeys [key [key ...]] [arg [arg ...]]

第一个参数 script 是脚本的源代码
第二个参数 numkeys 是输入键名参数的数量
后面的就是 key 和 参数。

例如:

> EVAL "return 'Hello, scripting!'" 0
"Hello, scripting!"

其中 "return 'Hello, scripting!'" 就是lua脚本,后面的0就是没有key 也没有参数,可以看到redis返回的就是脚本的返回值。

还有一种方式就是 写一个固定的脚本传递参数,比如

> EVAL "return ARGV[1]" 0 'hello scripting'
"hello scripting"
> EVAL "return ARGV[1]" 0 hello scripting
"hello"
> EVAL "return ARGV[3]" 0 hello scripting
(nil)

可以看到是从[1] 开始获取,而不是[0],参数是以空格隔开,如果超出范围返回nil。

一个使用key的例子

> EVAL "return { KEYS[1], KEYS[2], ARGV[1], ARGV[2], ARGV[3] }" 2 key1 key2 arg1 arg2 arg3
1) "key1"
2) "key2"
3) "arg1"
4) "arg2"
5) "arg3"

可以看到这个lua脚本可以使用{}返回多个值。不知道这个在java 里面返回的是个字符串还是list。

2,调用redis命令

可以通过 redis.call() 或 redis.pcall() 从Lua脚本调用Redis命令。两者几乎相同,除了调用 redis.call() 函数时产生的错误会直接返回到执行该函数的客户端。相反,调用 redis.pcall() 函数时遇到的错误会返回到脚本的执行上下文。
例子:

> EVAL "return redis.call('SET', KEYS[1], ARGV[1])" 1 foo bar
OK

简单的调用了一个set命令,看起来没有意义,但是多了可以保证原子性就有意义了,比如

> EVAL "local a=redis.call('SET',KEYS[1],ARGV[1]) local b=redis.call('SET',KEYS[2],ARGV[2]) return a and b" 2 k1 k2 v1 v2
OK

3,脚本缓存

> SCRIPT LOAD "return 'Immabe a cached script'"
"c664a3bf70bd1d45c4284ffebb65a6f2299bfc9f"
> EVALSHA c664a3bf70bd1d45c4284ffebb65a6f2299bfc9f 0
"Immabe a cached script"

可以看到使用script load 缓存一个脚本,返回一个ID,之后可以通过evalsha ID 来调用它。

至于lua脚本语言这个东西,摸索着写写就熟悉了。举几个例子:
获取并删除

local value = redis.call('get', KEYS[1]) if value then redis.call('del', KEYS[1]) return value else return nil end

解释,定义一个变量value如果获取到了keys[1]的值,就是删除这个值并返回OK否则返回nil,还可以写成

if redis.call('get', KEYS[1]) == ARGV[1] then return redis.call('del', KEYS[1]) else return 0 end

看起来跟shell脚本差不多吧。

到此这篇关于redis执行lua脚本的实现的文章就介绍到这了,更多相关redis执行lua脚本内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • redis学习之RDB、AOF与复制时对过期键的处理教程

    redis学习之RDB、AOF与复制时对过期键的处理教程

    这篇文章主要给大家介绍了关于redis学习之RDB、AOF与复制时对过期键处理的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用redis具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-11-11
  • Linux快速部署Redis

    Linux快速部署Redis

    这篇文章介绍了Linux下快速部署Redis的方法,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-01-01
  • 详解Redis中的List是如何实现的

    详解Redis中的List是如何实现的

    List 的 Redis 中的 5 种主要数据结构之一,它是一种序列集合,可以存储一个有序的字符串列表,顺序是插入的顺序,本文将给大家介绍了一下Redis中的List是如何实现的,需要的朋友可以参考下
    2024-05-05
  • Redis利用Pipeline加速查询速度的方法

    Redis利用Pipeline加速查询速度的方法

    这篇文章主要给大家介绍了关于Redis利用Pipeline加速查询速度的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Redis具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-07-07
  • Redis基本数据类型Zset有序集合常用操作

    Redis基本数据类型Zset有序集合常用操作

    这篇文章主要为大家介绍了redis基本数据类型Zset有序集合常用操作,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-05-05
  • redis在Windows中下载及安装、设置教程

    redis在Windows中下载及安装、设置教程

    这篇文章主要介绍了Windows中redis的下载及安装、设置教程,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-12-12
  • 关于分布式锁的三种实现方式

    关于分布式锁的三种实现方式

    这篇文章主要介绍了关于分布式锁的三种实现方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • redis数据结构之压缩列表

    redis数据结构之压缩列表

    这篇文章主要介绍了redis数据结构之压缩列表,压缩列表是列表list和hash数据结构的底层实现之一,是redis为了节约内存而开发的,由一系列特殊编码的连续内存块组成的顺序型数据结构,下面详细内容需要的小伙伴可以参考一下
    2022-03-03
  • Redis哨兵模式介绍

    Redis哨兵模式介绍

    这篇文章介绍了Redis哨兵模式,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-02-02
  • 基于redis乐观锁实现并发排队

    基于redis乐观锁实现并发排队

    这篇文章主要介绍了基于redis乐观锁实现并发排队的相关资料,需要的朋友可以参考下
    2022-12-12

最新评论