Redis 执行Lua脚本

Redis 执行lua 脚本

redis incr 命令当Key不存在时会默认设置key 并自增为1,如果需要在key不存在时重新初始化key 可以在应用程序中判断,也可以直接使用lua脚本

Redis 执行lua脚本命令

Script load

将脚本 script 添加到Redis服务器的脚本缓存中,并不立即执行这个脚本,而是会立即对输入的脚本进行求值。并返回给定脚本的 SHA1 校验和。如果给定的脚本已经在缓存里面了,那么不执行任何操作。

bash 复制代码
script load "local exists = redis.call('exists', KEYS[1]); if (exists == 1) then return redis.call('incr', KEYS[1]); end return nil;"

返回: 66dbc284948b243d16fd97265e0eac41567c29ed

需要调用该脚本时可以使用

bash 复制代码
 EVALSHA 66dbc284948b243d16fd97265e0eac41567c29ed  1 testIncr

1代表参数下标

testIncr 代表 参数值

直接调用lua脚本

bash 复制代码
 eval "local exists = redis.call('exists', KEYS[1]); if (exists == 1) then return redis.call('incr', KEYS[1]); end return nil;" 1 testIncr

判断脚本是否存在

bash 复制代码
SCRIPT EXISTS 66dbc284948b243d16fd97265e0eac41567c29ed

杀掉Lua脚本

bash 复制代码
SCRIPT KILL

清空Lua脚本

bash 复制代码
SCRIPT FLUSH

上述命令可以新增一个参数,用以设置在Key不存在时,初始化Key的值,有需要的自行改造

相关推荐
曹牧4 小时前
Oracle:前缀匹配之REGEXP_LIKE
数据库·oracle
暴躁小师兄数据学院6 小时前
【AI大数据工程师特训笔记】第05讲:关联查询
数据库·sql·oracle
倔强的石头_7 小时前
《Kingbase护城河》——跨平台环境下的数据库联调实战
数据库
lzhdim7 小时前
SQL 入门 17:MySQL 数据类型:从字符串到 JSON 的全面解析
数据库·sql·mysql·json
杨云龙UP7 小时前
Oracle RAC / ODA 生产环境指定 PDB 启动 SOP
linux·运维·数据库·oracle
kingwebo'sZone7 小时前
在Cent上安装Mysql 8.0的遇到的问题和解决办法
数据库·mysql·adb
幽络源小助理7 小时前
最新知识付费系统网站源码 PC+H5双端 附安装教程 – 幽络源源码网
大数据·数据库
小白考证进阶中8 小时前
Oracle OCP证书报考&考试全指南
数据库·oracle·oracle ocp·ocp认证·oracle认证·甲骨文认证·oracle ocp题库
Leon-Ning Liu9 小时前
【真实经验分享】 ORA-600 [qesmaGetTblSeg1]
数据库·oracle
与数据交流的路上9 小时前
MySQL 优化 -- 相关
数据库·mysql