广告
返回顶部
首页 > 资讯 > 数据库 >Redis使用lua脚本的案例分析
  • 815
分享到

Redis使用lua脚本的案例分析

2024-04-02 19:04:59 815人浏览 八月长安
摘要

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

这篇文章主要介绍了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 101
1) "100"
2) "101"
127.0.0.1:6379> eval "return {KEYS[1],KEYS[2],ARGV[1],ARGV[2]}" 2 key1 key2 first second
1) "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) 1
127.0.0.1:6379> ttl test
(integer) 59
127.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

<?php 

$lua = <<<EOF
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

EOF;

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

运行:

$ redis-cli set lua:incrbymul 0
OK
$ 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脚本的案例分析”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网数据库频道,更多相关知识等着你来学习!

您可能感兴趣的文档:

--结束END--

本文标题: Redis使用lua脚本的案例分析

本文链接: https://www.lsjlt.com/news/54996.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Redis使用lua脚本的案例分析
    这篇文章主要介绍了Redis使用lua脚本的案例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。版本:自2.6.0起可用。时间复杂度:取决...
    99+
    2022-10-18
  • redis中怎么使用lua脚本
    这篇文章给大家分享的是有关redis中怎么使用lua脚本的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一:Lua脚本说来也巧,redis的大老板给了你解决这种问题的方法,那就是L...
    99+
    2022-10-18
  • redis中lua脚本使用教程
    目录一、背景二、使用lua脚本三、lua和redis数据类型转换四、lua脚本中输出日志五、一个简单限流的案例六、lua脚本的debug七、参考文档一、背景 在使用redis的过程中...
    99+
    2022-11-12
  • PHP和Redis中的LUA脚本使用方法
    PHP和Redis中的LUA脚本使用方法LUA 是一种轻量级的脚本语言,旨在提供高效的嵌入式扩展功能。Redis 是一种开源的 NoSQL 数据库,提供高效的键值存储和缓存功能。在 Redis 中使用 LUA 脚本可以大大提高数据处理效率和...
    99+
    2023-05-15
    PHP redis Lua脚本
  • Python趣味脚本的案例分析
    这篇文章主要介绍了Python趣味脚本的案例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1.图片尺寸缩小所需库:opencv-python对于图片的放大和缩小,是我们经...
    99+
    2023-06-29
  • Redis中Lua脚本的使用和设置超时
    目录EVAL命令简介eval格式特性执行流程关于脚本超时SCRIPT KILL 命令SHUTDOWN NOSAVE 命令参考Redis提供了Lua脚本功能来让用户实现自己的原子命令,...
    99+
    2022-11-12
  • Java生态/Redis中如何使用Lua脚本
    文章目录 一、安装LUA1)简单使用 二、lua语法简介1、注释1)单行注释2)多行注释 2、关键字3、变量1)全局变量2)局部变量 4、数据类型1)Lua数组2)字符串操作 5、if-else6、循环1)fo...
    99+
    2023-08-19
    lua java redis
  • Java生态/Redis中怎么使用Lua脚本
    本篇内容主要讲解“Java生态/Redis中怎么使用Lua脚本”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java生态/Redis中怎么使用Lua脚本”吧!一、安装LUAMac上安装LUA很简...
    99+
    2023-07-05
  • redis中bigkey扫描脚本的示例分析
    这篇文章给大家分享的是有关redis中bigkey扫描脚本的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。我对这个脚本进行了一个压力测试,在redis的内存为15G,ke...
    99+
    2022-10-18
  • 简介Lua脚本与Redis数据库的结合使用
    可能你已经听说过Redis 中嵌入了脚本语言,但是你还没有亲自去尝试吧? 这个入门教程会让你学会在你的Redis 服务器上使用强大的lua语言。 Hello, Lua! 我们的第一个Redis Lua ...
    99+
    2022-06-04
    脚本 数据库 简介
  • HTML脚本使用的示例分析
    小编给大家分享一下HTML脚本使用的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!JavaScript 使 HTML 页...
    99+
    2022-10-19
  • springboot中使用redis并且执行调试lua脚本
    目录原因:1、创建一个基本的web项目2、配置redis3、测试redis 的lua脚本4、技术点5、调试方式1、进入服务关闭关闭正在运行的服务器2、从命令行启动redis3、在lu...
    99+
    2022-11-13
  • Redis调用Lua脚本及使用场景快速掌握
    目录一、阅读本文前置条件二、为什么需要Lua脚本三、学点Lua语法3.1.一个简单的例子3.2.仔细看下Lua脚本里的内容3.3. 复杂点的例子四、Lua脚本预加载五、一个修改 JS...
    99+
    2022-11-13
  • 基于Redis实现分布式锁的方法(lua脚本版)
    1、前言 在Java中,我们通过锁来避免由于竞争而造成的数据不一致问题。通常我们使用synchronized 、Lock来实现。但是Java中的锁只能保证在同一个JVM进程内中可用...
    99+
    2022-11-12
  • redis脚本命令执行问题实例分析
    这篇文章主要介绍“redis脚本命令执行问题实例分析”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“redis脚本命令执行问题实例分析”文章能帮助大家解决问题。1、redis-cli命令行中执行:#&...
    99+
    2023-06-29
  • redis使用Lua脚本解决多线程下的超卖问题及原因解析
    目录一.多线程下引起的超卖问题呈现二.使用Lua脚本解决多线程下超卖的问题以及为什么三.为什么使用Lua脚本就能解决多线程下的超卖问题呢?一.多线程下引起的超卖问题呈现 1.1.我先...
    99+
    2023-05-19
    redis多线程超卖 lua脚本解决超卖问题
  • HTML的脚本实例分析
    这篇文章主要介绍了HTML的脚本实例分析的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇HTML的脚本实例分析文章都会有所收获,下面我们一起来看看吧。    ...
    99+
    2022-10-19
  • redis比mysql快的案例分析
    这篇文章给大家分享的是有关redis比mysql快的案例分析的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。Redis将所有数据放在内存中,非数据同步正常工作中,是不需要从磁盘读取...
    99+
    2022-10-18
  • Redis和队列的案例分析
    这篇文章给大家分享的是有关Redis和队列的案例分析的内容。小编觉得挺实用的,因此分享给大家做个参考。一起跟随小编过来看看吧。概要Redis不仅可作为缓存服务器,还可用作消息队列。它的列表类型天生支持用作消...
    99+
    2022-10-18
  • redis之List操作的案例分析
    小编给大家分享一下redis之List操作的案例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!List操作,redis中的L...
    99+
    2022-10-18
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作