Redis系列——Lua脚本和redis事务的应用

介绍

Lua脚本

背景

Redis是一种抽象数据类型的特定领域语言,由各种命令组成。大多数命令专门用于操作不通的数据类型。每次发送命令均需要执行至此网络请求。所以Redis提供了一个编程接口,支持服务器执行用户自定义的任意脚本。有助于减少网络流量,并提高整体性能。在脚本中可以执行多个命令,封装一定的业务逻辑。

运行脚本

首先,自Redis2.6.0以来,EVAL命令支持运行服务器端脚本。Eval脚本提供了一种快速而直接的方法,让Redis临时运行脚本。这意味着脚本必须在应用程序中维护,以便于随时加载。随着应用程序的发展,这种方法后续更难开发和维护。

其次,在v7.0中添加的Redis函数本质上是作为一类数据库元素的脚本。因此,函数将脚本与应用程序逻辑分离,并支持脚本的独立开发、测试和部署。若要使用函数,需要先加载它们,然后才能供所有连接的客户端使用。在这种情况下,将函数加载到数据库将成为一项管理部署任务(例如加载Redis模块),这会将脚本与应用程序分开。

在运行脚本或函数时,Redis保证其原子执行。脚本的执行会在整个时间内阻止所有服务器活动,类似于事务的语义。这些语义意味着脚本的所有效果要么尚未发生,要么已经发生。已执行脚本的阻塞语义始终适用于所有连接的客户端。

所以必须要注意的是执行的脚本不是是一个慢脚本。如果执行过慢,会阻塞所有的客户端请求。

用法

使用 EVAL 命令开始使用 Redis 编写脚本。

> EVAL "return 'Hello, scripting!'" 0
"Hello, scripting!"

在此示例中,EVAL采用两个参数。第一个参数是一个字符串,由脚本的Lua源代码组成。该脚本不需要包含Lua函数的任何定义。它只是一个将在Redis引擎上下文中运行的Lua程序。

第二个参数是脚本正文后面的参数数,从第三个参数开始,表示Redis键名。在此示例中,我们使用值0,因为我们没有为脚本提供任何参数,无论是否为键的名称。

执行上下文可以通过KEYS和ARGV全局运行时变量使参数可供脚本使用。KEYS表预先填充了在执行脚本之前提供给脚本的所有键名参数,而ARGV表具有类似的用途,但用于常规参数。

redis> EVAL "return { KEYS[1], KEYS[2], ARGV[1], ARGV[2], ARGV[3] }" 2 key1 key2 arg1 arg2 arg3
1) "key1"
2) "key2"
3) "arg1"
4) "arg2"
5) "arg3"

Redis事务

原理

Redis事务允许执行一组命令在一个步骤中,它们以MULTIEXECDISCARD和WATCH命令为中心。Redis事务提供两项重要保证:

  • 事务中的所有命令都序列化并执行顺序。另一个客户端发送的请求永远不会在执行Redis事务的过程中提供服务。这保证了命令作为单个命令执行隔离操作。

  • EXEC命令触发事务中所有命令的执行,因此如果客户端在事务,在调用EXEC命令之前,不执行任何操作,如果调用EXEC命令,则所有执行操作。使用仅追加文件时,Redis确保使用单个write(2) syscall将事务写入磁盘。但是,如果Redis服务器崩溃或被系统管理员杀死在某种程度上,可能只有部分操作已注册。Redis将在重新启动时检测到此情况,并退出并显示错误。使用redis-check-aof该工具可以修复仅附加将删除部分事务的文件,以便服务器可以重新启动。

从版本2.2开始,Redis以乐观锁定的形式,以一种非常相似的方式检查和设置(CAS)操作。

用法

使用MULTI命令输入Redis事务。命令总是回复OK。此时,用户可以发出多个命令。Redis不会执行这些命令,而是会排队他们。调用EXEC后,将执行所有命令。

相反,调用DISCARD将刷新事务队列并退出交易。

> MULTI
OK
> INCR foo
QUEUED
> INCR bar
QUEUED
> EXEC
1) (integer) 1
2) (integer) 1

从上面的会话中可以清楚地看出,EXEC返回一个回复数组,其中每个元素都是单个命令的回复在事务中,命令的发出顺序相同。

事务中命令错误

从Redis2.6.5开始,服务器会在命令累积过程中检测到错误。然后,它将拒绝执行事务,在EXEC期间返回错误,从而丢弃事务。

相反,EXEC之后发生的错误不会以特殊方式处理:即使某些命令在事务期间失败,所有其他命令也会被执行。

回滚?

Redis事务不支持回滚。

Redis Lua脚本和事务使用场景

对于redis中的事务类操作,还需要考虑其他事项,即redis脚本,它们是事务性的。可以用 Redis 事务 做的所有事情,也可以用脚本来做,通常脚本会更简单、更快捷。

缺点

Lua脚本缺点

  1. 所有客户端必须要维护所有的脚本副本。
  2. EVAL是一种反模式。它们往往在短期内看起来有效,但长期来看会增加技术债务、降低代码质量和团队效率。
  3. 脚本之间无法互相调用;
  4. 无法直接支持redis cluster模式,需要运算key对应的哈希槽。

Redis事务缺点

  1. Redis事务不支持归滚;
  2. Redis事务每条命令都与redis服务器进行一次网络交互;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/673288.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

linux文件的IO函数

open函数: 作用:打开或者新建一个文件 原型: int open(const char*pathname,int flags); int open(const char*pathname,int flags,mode_t mode); 参数: pathname:路径 flags:1-> O_RONLY 只读打开 2 -> O_WONLY只写打开 3->…

83 CTF夺旗-Python考点SSTI反序列化字符串

这里写目录标题 CTF各大题型简介演示案例:CTF夺旗-Python-支付逻辑&JWT&反序列化CTF夺旗-Python-Flask&jinja2&SSTl模版注入CTF夺旗-Python-格式化字符串漏洞&读取对象 涉及资源: 我们这篇文章主要讲的是CTF在web渗透测试方向的3个考点 CTF各大…

elementui常用组件-个人版(间断更新)

Dialog 对话框 el-dialog <el-dialogtitle"提示":visible.sync"dialogVisible"width"30%":before-close"handleClose"><span>这是一段信息</span><span slot"footer" class"dialog-footer"…

代码随想录算法训练营|day25

第七章 回溯算法 216.组合总和III17.电话号码的字母组合代码随想录文章详解总结 216.组合总和III 回溯&#xff1a;i宽度约束&#xff0c;sum深度约束 func combinationSum3(k int, n int) [][]int {res : [][]int{}path : []int{}var help func(startIndex, sum, k, n int)h…

开源一套直播平台

博主开源一套直播平台,私信博主可获取源码 直播平台系统界面介绍

微信小程序(三十六)事件传参

注释很详细&#xff0c;直接上代码 上一篇 新增内容&#xff1a; 1.传参步骤 2.传参接收解构步骤 源码&#xff1a; index.wxml <button type"primary" bind:tap"onclick" mark:index"{{0}}" mark:remb"{{1}}" class"But&quo…

产品经理--分享在项目中产品与研发之间会遇到的问题 在面试这一岗位时,面试官常问的问题之一,且分享两大原则来回答面试官这一问题

目录 一.STAR原则 1.1 简介 1.2 如何使用 1.3 举例说明 二.PDCA原则 2.1 简介 2.2 如何使用 2.3 运用场景 2.4 举例说明 三.产品与研发的沟通痛点 3.1 沟通痛点的原因 3.2 分享案例 前言 本篇会详细阐明作为一个产品经理会在项目遇到的问题&#xff0c;如&#xff1a;产…

力扣_字符串4—编辑距离

题目 给你两个单词 w o r d 1 word1 word1 和 w o r d 2 word2 word2&#xff0c; 请返回将 w o r d 1 word1 word1 转换成 w o r d 2 word2 word2 所使用的最少操作数 。 你可以对一个单词进行如下三种操作&#xff1a; 插入一个字符删除一个字符替换一个字符 方法—动…

记录 | python 源码编译报错subprocess.CalledProcessError Command lsb_release

subprocess.CalledProcessError: Command (lsb_release, -a) returned non-zero exit status 1. 解决方法 find / -name lsb_releaserm -rf /usr/bin/lsb_release

张艺谋《主角》选角引发热议,周迅、赵丽颖、杨紫或成候选。

♥ 为方便您进行讨论和分享&#xff0c;同时也为能带给您不一样的参与感。请您在阅读本文之前&#xff0c;点击一下“关注”&#xff0c;非常感谢您的支持&#xff01; 文 |猴哥聊娱乐 编 辑|徐 婷 校 对|侯欢庭 近日&#xff0c;张艺谋执导的首部电视剧《主角》女主选角成为…

6.electron之上下文隔离,预加载JS脚本

如果可以实现记得点赞分享&#xff0c;谢谢老铁&#xff5e; Electron是一个使用 JavaScript、HTML 和 CSS 构建桌面应用程序的框架。 Electron 将 Chromium 和 Node.js 嵌入到了一个二进制文件中&#xff0c;因此它允许你仅需一个代码仓库&#xff0c;就可以撰写支持 Windows、…

【Linux】vim的基本操作与配置(上)

Hello everybody!今天我们要进入vim的讲解了。学会了vim,咱们就可以在Linux系统上做一些简单的编程啦&#xff01; 那么废话不多说&#xff0c;咱们直接进入正题&#xff01; 1.初识vim vim是一款多模式的文本编辑器&#xff0c;可以对一个文件进行编辑操作。 它一共有三个模…

2024年【化工自动化控制仪表】最新解析及化工自动化控制仪表考试资料

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 2024年【化工自动化控制仪表】最新解析及化工自动化控制仪表考试资料&#xff0c;包含化工自动化控制仪表最新解析答案和解析及化工自动化控制仪表考试资料练习。安全生产模拟考试一点通结合国家化工自动化控制仪表考…

《dx12 龙书》第四部分学习笔记——预备知识(下)

7、多重采样技术的原理 由于屏幕中显示的像素不可能是无穷小的&#xff0c;所以并不是任意一条直线都能在显示器上“平滑”而完美地呈现出来。即为以像素矩阵 &#xff08;matrix of pixels&#xff0c; 可以理解为“像素2D数组”&#xff09;逼近直线的方法所产生的“阶梯” &…

EDM营销平台哪个好?推荐的邮件营销平台?

EDM邮件营销平台有哪些&#xff1f;外贸EDM邮件营销平台有哪些&#xff1f; EDM营销平台已成为企业推广产品和服务的重要工具。但是&#xff0c;面对市场上众多的EDM营销平台&#xff0c;究竟哪个更好呢&#xff1f;下面&#xff0c;蜂邮EDM将从平台功能、用户体验、数据分析和…

关于五子棋算法的学习

基于python的AI五子棋实现&#xff08;极大极小值搜索和alpha beta剪枝&#xff09;_pygame五子棋ai算法-CSDN博客 csdn搜索&#xff1a;AI五子棋实现 AI人机对战五子棋游戏【Python(pygame)AI】并实现软件输出_python设计两个ai对战黑白棋-CSDN博客z​​​​​​​z这个很详细…

Matlab使用点云工具箱进行点云配准

一、代码 source_pc pcread(bun_zipper.ply); target_pc pcread(bun_zipper2.ply); % 下采样 gridStep 0.001; ptCloudA pcdownsample(source_pc,gridAverage,gridStep); ptCloudB pcdownsample(target_pc,gridAverage,gridStep); % 初始变换矩阵 tform_initial affine3…

第三百一十二回

文章目录 1. 概念介绍2. 实现方法2.1 obscureText属性2.2 decoration属性 3. 示例代码4. 内容总结 我们在上一章回中介绍了"如何实现倒计时功能"相关的内容&#xff0c;本章回中将介绍如何实现密码输入框.闲话休提&#xff0c;让我们一起Talk Flutter吧。 1. 概念介绍…

C语言笔试题之实现C库函数 pow()(递归的思想)

实例要求&#xff1a; 1、请你实现C库函数 pow()&#xff08;stdio.h & math.h&#xff09; &#xff0c;即计算 x 的整数 n 次幂函数&#xff08;即x^n &#xff09;&#xff1b;2、函数声明&#xff1a;double myPow(double x, int n)&#xff1b;参数&#xff1a;1、x …

YOLOv8改进 更换轻量级网络结构

一、GhostNet论文 论文地址:1911.11907.pdf (arxiv.org) 二、 GhostNet结构 GhostNet是一种高效的目标检测网络,具有较低的计算复杂度和较高的准确性。该网络采用了轻量级的架构,可以在计算资源有限的设备上运行,并能够快速地实时检测图像中的目标物体。 GhostNet基于Mo…