千家信息网

Redis使用lua脚本的案例分析

发表于:2024-10-04 作者:千家信息网编辑
千家信息网最后更新 2024年10月04日,这篇文章主要介绍了Redis使用lua脚本的案例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。版本:自2.6.0起可用。时间复杂度
千家信息网最后更新 2024年10月04日Redis使用lua脚本的案例分析

这篇文章主要介绍了Redis使用lua脚本的案例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

版本:自2.6.0起可用。

时间复杂度:取决于执行的脚本。

使用Lua脚本的好处:

  • 减少网络开销。可以将多个请求通过脚本的形式一次发送,减少网络时延。

  • 原子操作。redis会将整个脚本作为一个整体执行,中间不会被其他命令插入。因此在编写脚本的过程中无需担心会出现竞态条件,无需使用事务。

  • 复用。客户端发送的脚步会永久存在redis中,这样,其他客户端可以复用这一脚本而不需要使用代码完成相同的逻辑。

如何使用

基本使用

命令格式:

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

说明:

  • script是第一个参数,为Lua 5.1脚本。该脚本不需要定义Lua函数(也不应该)。

  • 第二个参数numkeys指定后续参数有几个key。

  • key [key ...],是要操作的键,可以指定多个,在lua脚本中通过KEYS[1], KEYS[2]获取

  • arg [arg ...],参数,在lua脚本中通过ARGV[1], ARGV[2]获取。

简单实例:

127.0.0.1:6379> eval "return ARGV[1]" 0 100 "100"127.0.0.1:6379> eval "return {ARGV[1],ARGV[2]}" 0 100 1011) "100"2) "101"127.0.0.1:6379> eval "return {KEYS[1],KEYS[2],ARGV[1],ARGV[2]}" 2 key1 key2 first second1) "key1"2) "key2"3) "first"4) "second"127.0.0.1:6379> eval "redis.call('SET', KEYS[1], ARGV[1]);redis.call('EXPIRE', KEYS[1], ARGV[2]); return 1;" 1 test 10 60(integer) 1127.0.0.1:6379> ttl test(integer) 59127.0.0.1:6379> get test"10"

注:

  • {}在lua里是指数据类型table,类似数组。

  • redis.call()可以调用redis命令。

命令行里使用

如果直接使用redis-cli命令,格式会有点不一样:

redis-cli --eval lua_file key1 key2 , arg1 arg2 arg3

注意的地方:

  • eval 后面参数是lua脚本文件,.lua后缀

  • 不用写numkeys,而是使用,隔开。注意,前后有空格。

示例:

incrbymul.lua

local num = redis.call('GET', KEYS[1]); if not num then return 0;else local res = num * ARGV[1];  redis.call('SET',KEYS[1], res);  return res;end

命令行运行:

$ redis-cli --eval incrbymul.lua lua:incrbymul , 8(integer) 0$ redis-cli incr lua:incrbymul (integer) 1$ redis-cli --eval incrbymul.lua lua:incrbymul , 8(integer) 8$ redis-cli --eval incrbymul.lua lua:incrbymul , 8(integer) 64$ redis-cli --eval incrbymul.lua lua:incrbymul , 2(integer) 128

由于redis没有提供命令可以实现将一个数原子性的乘以N倍,这里我们就用Lua脚本实现了,运行过程中确保不会被其它客户端打断。

phpredis里使用

接着上面的例子:

incrbymul.php

connect('127.0.0.1', 6379);$ret = $redis->eval($lua, array("lua:incrbymul", 2), 1);echo $ret;

运行:

$ redis-cli set lua:incrbymul 0OK$ redis-cli incr lua:incrbymul(integer) 1$ php incrbymul.php 2$ php incrbymul.php 4

eval原型:

Redis::eval(string script, [array keys, long num_keys])

eval函数的第3个参数为KEYS个数,phpredis依据此值将KEYS和ARGV做区分。

感谢你能够认真阅读完这篇文章,希望小编分享的"Redis使用lua脚本的案例分析"这篇文章对大家有帮助,同时也希望大家多多支持,关注行业资讯频道,更多相关知识等着你来学习!

脚本 命令 参数 篇文章 客户 客户端 运行 案例 案例分析 分析 个数 函数 原子 多个 格式 网络 过程 中通 复用 复杂 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 软件开发安全培训文档 陕西浪潮服务器虚拟化云空间 江苏赛普网络技术有限公司 数据库同时搜所有表 关于网络安全现状的调研报告 大数据与网络技术专业考研 制造执行系统软件开发服务商 微信算卦软件开发 乡村网络安全责任制工作细则 上海优势软件开发厂家报价 管理linux服务器软件 网络文明和网络安全是一个东西 连云港app软件开发价格 笔记本无线网络服务器 绍兴创新网络技术口碑推荐 数据库主键设置要求 戴尔服务器管理网配置 数据库插入数字类型的值 辅料安全数据库 穿越火线服务器名称显示数字 网络安全法2021年是第几届 经济技术开发区奥思网络技术 重庆平伟科技集团网络安全 网络安全大赛中文名字 三年级手抄小报网络安全 csgo进去前选服务器 花魁咖啡 解析服务如何在服务器查看 中国第一部网络安全立法i hbase单机版数据库安装
0