12⑦0.0.1:6379> eval "return {KEYS[1],ARGV[1],ARGV[2]}" 1 1 ONE TWO 1) "1" 2) "ONE" 3) "TWO"
在Lua脚本中可以通过使用redis.call()或redis.pcall()函数调用redis命令.
12⑦0.0.1:6379> set foo bar OK 12⑦0.0.1:6379> eval "return redis.call('set','foo','bibi')" 0 OK 12⑦0.0.1:6379> get foo "bibi" 12⑦0.0.1:6379> eval "return redis.call('set',KEYS[1],'bar')" 1 foo
至于redis.call(),redis.pcall()的不同,在于错误提示不一样
12⑦0.0.1:6379> eval "return redis.call('setset','yyyy','oo')" 0 (error) ERR Error running script (call to f_9b37f897c55c73737f181184c9781281dc9b45e3): @user_script:1: @user_script: 1: Unknown Redis command called from Lua script 12⑦0.0.1:6379> eval "return redis.pcall('setset','yyyy','oo')" 0 (error) @user_script: 1: Unknown Redis command called from Lua script 12⑦0.0.1:6379>
Redis与Lua数据类型的转换
Lua数据类型转Redis类型
Redis数据类型转lua数据类型:
Lua number
Lua string
Lua table (may have other Redis data types nested)
Lua table with a single ok field containing the status
Lua table with a single err field containing the error
Lua false boolean type
Redis数据类型和lua数据类型并不完全对应:
Lua的编号如果非整数,应作为字符串返回,因为总是转为Redis整数类型
所以,该脚本就别搞那么复杂吧,当然,看清况,该复杂也没辙.
Eval执行的脚本不从缓存里拿,而Evalsha执行的脚本从缓存拿,跟sha1校验码从服务器缓存里拿.(sha1就好像身份证)
12⑦0.0.1:6379> script load "return 5" #往缓存里加入脚本 , 返回sha1校验码 "4ca238f611c9d0ae4e9a75a5dbac22aedc379801" 12⑦0.0.1:6379> script exists 4ca238f611c9d0ae4e9a75a5dbac22aedc379801 #是否存在某脚本 1) (integer) 1 12⑦0.0.1:6379> evalsha 4ca238f611c9d0ae4e9a75a5dbac22aedc379801 0 #执行脚本 (integer) 5 12⑦0.0.1:6379> script flush OK 12⑦0.0.1:6379> script exists 4ca238f611c9d0ae4e9a75a5dbac22aedc379801 1) (integer) 0 #0表示不存在了 12⑦0.0.1:6379> evalsha 4ca238f611c9d0ae4e9a75a5dbac22aedc379801 0 (error) NOSCRIPT No matching script. Please use EVAL. #异常了
先写到这,待深入.
以上就是土嘎嘎小编为大家整理的Redis Eval Script相关主题介绍,如果您觉得小编更新的文章只要能对粉丝们有用,就是我们最大的鼓励和动力,不要忘记讲本站分享给您身边的朋友哦!!