在redis中使用lua脚本

  在实际工作过程中,可以使用lua脚本来解决一些需要保证原子性的问题,而且lua脚本可以缓存在redis服务器上,势必会增加性能。 
不过lua也会有很多限制,在使用的时候要注意。

  在Redis中执行Lua脚本有两种方法:eval和evalsha

eval

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

  其中: <1> script:你的lua脚本

    <2> numkeys:  key的个数

    <3> key:redis中各种数据结构的替代符号

    <4> arg: 你的自定义参数

  举个例子:

eval "return {KEYS[1],KEYS[2],ARGV[1],ARGV[2]}" 2 user age ysl 21

  第一个参数的字符串就是script,也就是lua脚本。2表示keys的个数,KEYS[1] 就是 username的占位符, KEYS[2]就是 age的占位符,ARGV[1]就是ysl的占位符,ARGV[2]就是20的占位符,,以此类推,,,所以最后的结果应该就是:{return username age ysl 20}

  通常境况下,我们不要在redis-cli中直接写lua脚本,这样非常不方便编辑,通常情况下我们都是把lua script放到一个lua文件中,然后执行这个lua脚本

  编写lua脚本test.lua,内容如下:

return {KEYS[1],KEYS[2],ARGV[1],ARGV[2]}  

  然后我们通过下面命令执行,这种方式和前面介绍的不一样,参数 --eval script  key1 key2 , arg1 age2 这种模式,key和value用一个逗号隔开就好了,

./redis-cli --eval /usr/redis/sbin/test.lua username age , ysl 20

evalsha

  将Lua脚本加载到Redis服务端,得到该脚本的sha1校验和,evalsha命令使用sha1作为参数可以直接执行对应的Lua脚本,避免每次发送Lua脚本的开销。这样客户端就不需要每次执行脚本内容,而脚本也会常驻在服务端,脚本内容得到了复用。

  加载脚本: script load命令可以将脚本内容加载到Redis内存中。

 redis-cli script load “$(cat lua_get.lua)” 

  执行脚本:evalsha 脚本sha1值 key个数 key列表 参数列表 

lua的Redis API

  lua可以使用redis.call函数实现对Redis的访问

  redis.call(“set”,”hello”,”world”)

  redis.call(“get”,”hello”)

  除此之外Lua还可以使用redis.pcall函数实现对Redis的调用,redis.call和redis.pcall的不同在于,如果redis.call执行失败,那么脚本执行结束会直接返回错误,而redis.pcall会忽略错误继续执行脚本。

Lua脚本功能为Redis开发和运维人员带来的如下三个好处:

  • 1.Lua脚本在Redis中是原子执行的,执行过程中间不会插入其他命令。
  • 2.Lua脚本可以帮助开发和运维人员创造出自己定制的命令,并可以将这些命令常驻在Redis内存中,实现复用的效果。
  • 3.Lua脚本可以将多条命令一次性打包,有效地减少网络开销。

Redis如何管理Lua脚本

1.script load

此命令用于将Lua脚本加载到Redis内存中

2.script exists

scripts exists sha1 [sha1 …]

此命令用于判断sha1是否已经加载到Redis内存中

3.script flush

此命令用于清除Redis内存已经加载的所有Lua脚本,在执行script flush后,sha1不复存在。

4.script kill

此命令用于杀掉正在执行的Lua脚本。

抢红包中Redis和Lua命令的使用:

首先编写lua脚本

在Java类中,String script=”“;进行拼接。

获取底层Redis的操作对象

Jedis jedis=(Jedis) redisTemplate.getConnectionFactory().getConnection().getNativeConnection();

如果脚本没有加载过,那么进行加载,这样就会返回一个sha1编码

if(sha1==null)
    sha1=jedis.scriptLoad(script);

执行脚本,返回结果

Object res=jedis.evalsha(sha1,1,redisPacketId +”“,args);

根据res的值来确定是否保存到数据库。

原文地址:https://www.cnblogs.com/senlinyang/p/8820572.html

时间: 2024-08-07 20:59:32

在redis中使用lua脚本的相关文章

redis中使用java脚本实现分布式锁

转载于:http://www.itxuexiwang.com/a/shujukujishu/redis/2016/0216/115.html?1455860390 edis被大量用在分布式的环境中,自然而然分布式环境下的锁如何解决,立马成为一个问题.例如我们当前的手游项目,服务器端是按业务模块划分服务器的,有应用服,战斗服等,但是这两个vm都有可能同时改变玩家的属性,这如果在同一个vm下面,就很容易加锁,但如果在分布式环境下就没那么容易了,当然利用redis现有的功能也有解决办法,比如redis

在Unity3d中解析Lua脚本的方法

由于近期项目中提出了热更新的需求,因此本周末在Lua的陪伴下度过.对Lua与Unity3d的搭配使用,仅仅达到了一个初窥门径的程度,记录一二于此.水平有限,欢迎批评指正. 网络上关于Lua脚本和Unity3d的配合使用的资料不多,例子工程大多相同.大概了解到针对性的插件有uLua.UniLua.KopiLua三种.试用了前两种,抛开效率与安全性不说,感觉uLua试用起来比较简单,本文只介绍uLua的使用步骤. uLua的原理是在Unity3d中解析字符串形式的Lua脚本,让Lua与C#相互传递参

Php+Redis 实现Redis提供的lua脚本功能

<?php require_once "predis-0.8/autoload.php"; $config['schema'] = 'tcp'; $config['host']= "192.168.1.7"; $config['port'] = 6379; $redis = new Predis\Client($config); class wode extends Predis\Command\ScriptedCommand { public functio

C++中嵌入Lua脚本环境搭建

第一步(环境准备工作): 工具: ●LuaForWindows_v5.1.4-46.exe傻瓜式安装. 作用:此工具可以在windows环境下编译运行Lua脚本程序.安装完成后会有两个图标:Lua和SciTE.Lua是命令行,SciTE是图形运行环境,两个都可以编译运行,看个人喜好. ●VS2012大家都会,此处省略若干字... 第二步(在VS2012下新建并运行C++中嵌入Lua脚本程序): ●打开VS2012,新建一个控制台的C++空项目 ●配置Lua的安装路径和引用相关Lua库 1.右击新

【COCOS2DX-LUA 脚本开发之一】在Cocos2dX游戏中使用Lua脚本进行游戏开发(基础篇)并介绍脚本在游戏中详细用途!

[COCOS2DX-LUA 脚本开发之一]在Cocos2dX游戏中使用Lua脚本进行游戏开发(基础篇)并介绍脚本在游戏中详细用途! 分类: [Cocos2dx Lua 脚本开发 ] 2012-04-16 10:08 30803人阅读 评论(18) 收藏 举报 游戏脚本luaanimationpython 本站文章均为李华明Himi原创,转载务必在明显处注明:转载自[黑米GameDev街区] 原文链接: http://www.himigame.com/iphone-cocos2dx/681.htm

在PHP中使用redis来操作lua脚本,使用$redis-&gt;eval()命令时出错,参数传递无效

使用$redis->eval命令时传递三个参数,第一个为lua脚本文件,第二个为key,第三个参数为key的个数向lua中传递参数时,在key中定义好,即可,示例正确代码 用lua脚本循环 eval "local rst={}; for i,v in pairs(KEYS) do rst[i]=redis.call('hgetall', v) end; return rst" 2 user:1 user:2 $z=$redis->EVAL('local rst={}; fo

StackExchange.Redis加载Lua脚本进行模糊查询的批量删除和修改

前言 使用StackExchange.Redis没有直接相关的方法进行模糊查询的批量删除和修改操作,虽然可以通过Scan相关的方法进行模糊查询,例如:HashScan("hashkey", "*key*"),然后再使用相关的方法进行相关的批量操作,但是如果缓存数据量比较大,效率低下,那么可以使用Lua脚本进行模糊查询的批量操作:ScriptEvaluate(LuaScript.Prepare(...)). 通过keys进行模糊查询后的批量操作 批量删除 1 var

redis翻译_redis lua脚本

Available since 2.6.0.  加入版本2.6 Time complexity: Depends on the script that is executed. 时间复杂度: 取决于脚本的执行 出处:http://blog.csdn.net/column/details/redisbanli.html Introduction to EVAL  介绍EVAL EVAL and EVALSHA are used to evaluate scripts using the Lua i

spring boot 中使用LUA脚本

编写LUA脚本 该脚本功能:先检查redis中某个key的值是否与期望的值V1一致,如果一致则将其修改为新的值V2并返回true,否则返回false.其实就是CAS. local current = redis.call('GET', KEYS[1]) if current == ARGV[1] then redis.call('SET', KEYS[1], ARGV[2]) return true end return false 注意,lua脚本中的变量都要是local 的,不可以是全局变量