redis之事务分析

news2024/12/27 12:01:00

写在前面

本文一起看下redis提供的事务功能。

1:事务的ACID

A(Atomic)原子性,C(Consitency)一致性,I(Isolation)隔离性,D(Durability)持久性,其具体要求如下:

A:事务中所有的操作必须是原子的,要么全部执行,要么全部不执行。
C:事务执行前后,数据的状态不发生改变。
I:事务之间的数据不能相互影响,即不能同时修改相同的数据。
D:事务执行后,修改是持久的,即会保存到磁盘,保证不丢失。

一个完备的事务机制必须满足以上的四个特性,但也并不是必须全部满足。那么Redis事务针对这四个特性的满足情况如何呢,我们一起来看下。

2:Redis是如何支持事务的

Redis通过multi,exec来支持事务,执行multi后代表开始一个事务,接着我们就可以执行各种Redis指令,这些指令会被存储到一个队列中,等到执行exec时一起执行(可以保证以原子的方式执行),如下:

在这里插入图片描述

3:Redis事务对ACID的支持

3.1:A

A,Atomic,原子性,我们需要通过几种情况来分析。

3.1.1:所有命令都可正确执行

假如事务队列中的所有命令都能正确执行,Redis能保证其执行的原子性。

3.1.2:入队时发现命令错误

如果是入队时Redis就发现命令错误了,比如使用了一个不存在的指令PUT,当执行exec时,Redis会拒绝执行事务队列中的命令,如下:

127.0.0.1:6379> get a:stock
"1"
127.0.0.1:6379> get b:stock
"100"
127.0.0.1:6379> multi
OK
127.0.0.1:6379> decr a:stock
QUEUED
127.0.0.1:6379> incr b:stock
QUEUED
127.0.0.1:6379> PUT k v
(error) ERR unknown command 'PUT'
127.0.0.1:6379> exec
(error) EXECABORT Transaction discarded because of previous errors.
127.0.0.1:6379> get a:stock
"1"
127.0.0.1:6379> get b:stock
"100"

可以看到事务并没有执行,a:stock和b:stock的值也并没有改变。此时满足原子性。

3.1.3:执行时发现命令错误

有些命令,入队时Redis无法发现错误,但是执行时会错误,比如LPOP操作错误的数据类型,如下:

127.0.0.1:6379> get a:stock
"0"
127.0.0.1:6379> get b:stock
"100"
127.0.0.1:6379> multi
OK
127.0.0.1:6379> decr a:stock
QUEUED
127.0.0.1:6379> lpop b:stock
QUEUED
127.0.0.1:6379> exec
1) (integer) -1
2) (error) WRONGTYPE Operation against a key holding the wrong kind of value
127.0.0.1:6379> get a:stock
"-1"

可看到lpop b:stock执行错误,但是队列中其他指令正常执行了,此时不符合原子性。虽然有错误,Redis也没有回滚,因为Redis并没有提供回滚机制,虽然Redis没有提供事务回滚机制,但是却提供了discard命令,用来主动放弃事务,类似于MySQL的rollback,但只是一种主动的操作,如下:

127.0.0.1:6379> get a:stock
"-1"
127.0.0.1:6379> get b:stock
"100"
127.0.0.1:6379> multi
OK
127.0.0.1:6379> decr a:stock
QUEUED
127.0.0.1:6379> incr b:stock
QUEUED
127.0.0.1:6379> discard
OK
127.0.0.1:6379> get a:stock
"-1"
127.0.0.1:6379> get b:stock
"100"

3.2:C

C,Consistency,一致性,分成以下几种情况分析。

3.2.1:所有命令都可正确执行

此时因为所有的命令都正确执行了,所以能够保证一致性。

3.2.2:入队时发现命令错误

入队时发现命令,事务队列中的所有命令都不会执行,此时能够保证一致性。

3.2.3:执行时发现命令错误

执行命令时发现命令错误,此时,部分命令执行了,错误命令没有执行,不能保证一致性。

3.3:I

I,Isoation,隔离性,需要配合watch机制才能实现,watch机制的意思是,事务执行前,先监听某个key,在exec执行时,如果被监听的key发生了变化,则事务会放弃执行,如下:

在这里插入图片描述

此时隔离性是得到了保证的,因为相同的数据没有同时被不同的事务修改。如果是不使用watch机制的话,相同的值会同时被不同客户端修改,此时不具备隔离性,如下:

在这里插入图片描述

3.4:D

D,Durability,持久性,如果是Redis没有开启rdb或aof的话,不具备持久性,因为数据只会在内存,重启就丢失。然后看下开启了rdb或aof 的情况。

3.4.1:开启rdb

事务执行后,并不会立即生成快照,此时数据库宕机,数据会丢失,不具备持久性。

3.4.2:开启aof

appendfsync当配置为no,everysec时,事务执行后如果发生了数据库宕机,数据会丢失,不具备持久性。当配置为always时,数据其实也并不是直接写到aof文件中,而是先写到内存中,后续再同步到aof文件,因此,此时也不具备持久性。总结就是开启aof也不能让Redis具备持久性。

4:Redis ACID都支持啥

从前面的分析,Redis事务使用到的命令如下:

在这里插入图片描述

支持情况如下:

原子性:支持,当事务队列中的命令都正确时,redis会以原子的方式来执行。
一致性:支持,只有当命令执行时才发现错误时不支持,但是存在支持的场景我们就可以认为其支持。
隔离性:支持,需要配合watch机制。
持久性:不支持,但是redis作为内存数据库,这项不支持,其实影响不大。

写在后面

参考文章列表:

事务的【ACID】四大原则 。

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

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

相关文章

kubernetes学习之路--BadPods(Part1)

摘要:对Pod配置进行实战学习,以BadPods项目为例学习危险配置。 目录 一.BadPods介绍及使用 二.BadPods配置学习 2.1 less1--Everything allowed 基本操作学习 2.2 less1--Everything allowed 渗透学习 一.BadPods介绍及使用 项目地址:h…

西门子KTP1200触摸屏右上角出现黄色感叹号_报警指示器的组态与应用

西门子KTP1200触摸屏右上角出现黄色感叹号_报警指示器的组态与应用 设备运行时产生报警时通常会在画面右上角有个指示器在闪烁提示报警产生。 本次和大家分享报警指示器的组态和具体使用方法。 报警指示器的组态。 报警指示器使用警告三角来表示报警处于未决状态或要求确认。如…

数字验证学习笔记——SystemVerilog芯片验证15 ——随机约束和分布

一、随机和约束 1.1 随机 定向测试能找到你认为可能存在的缺陷,而随机测试可以找到你没有想到的缺陷。随机测试相对于定向测试可以减少相当多的代码量,而产生的激励较定向测试也更多样。 1.2 约束 我们想要的随机自由是一种合法的随机,需…

JAVA毕业设计——基于Springboot+vue的房屋租赁系统(源代码+数据库)

github代码地址 https://github.com/ynwynw/houserent2-public 毕业设计所有选题地址 https://github.com/ynwynw/allProject 基于Springboot的房屋租赁系统(源代码数据库) 一、系统介绍 本项目分为管理员、经纪人、维修员、普通用户四种角色 管理员角色包含以下功能&#…

C++——AVL树

目录 AVL 树 Insert 控制平衡因子 AVL树的旋转 AVL树验证 AVL树的性能 错误排查技巧 AVL 树 二叉搜索树虽可以缩短查找的效率,但如果数据有序或接近有序二叉搜索树将退化为单支树,查找元素相当于在顺序表中搜索元素,效率低下。因此&…

统计学 | 描述统计

一.导论 统计学是通过收集,整理,分析,描述数据等手段,以达到推断所测对象的本质,甚至预测对象未来的一门综合性科学。其目的是探索数据的内在数量规律性,以达到对客观事物的科学认识 统计的本业是消化数据…

pikachu靶场-4 SQL注入漏洞

SQL注入漏洞 在OWASP发布的TOP 10 中,注入漏洞一直是危害排名第一的漏洞,其中主要指的是SQL Inject漏洞。 一个严重的SQL注入漏洞,可能会直接导致一家公司破产! 数据库输入漏洞,主要是开发人员在构建代码时&#xf…

基于人眼视觉模型,实现码率、质量、成本的最优均衡

将编码器的优化目标从经典的保真度最高,调整为「主观体验最好」。 视觉是具有 「掩蔽效应」 的。 通俗地说,人眼作为图像信息的接收端,并不能精准捕捉到图像画面的所有变化。 例如,人眼对于画面中亮度的变化、静止的图像、画面整…

算法竞赛入门【码蹄集进阶塔335题】(MT2126-2150)

算法竞赛入门【码蹄集进阶塔335题】(MT2126-2150) 文章目录算法竞赛入门【码蹄集进阶塔335题】(MT2126-2150)前言为什么突然想学算法了?为什么选择码蹄集作为刷题软件?目录1. MT2126 奇偶序列2. MT2127 数组扦插3. MT2128 sort4. …

运放常见应用电路,有图有公式-运算放大器--点赞

声明: 本号对所有原创、转载文章的陈述与观点均保持中立,推送文章仅供读者学习和交流。文章、图片等版权归原作者享有,如有侵权,联系删除。 参考原文;《运放常见应用电路,有图有公式,建议收藏…

机器学习学习笔记(1)

字典特征提取 第一列表示北京 第二列表示上海 第三列表示深圳 第四列表示温度 前面三列 是的话用1 不是的话用0 什么时候用稀疏矩阵:比如上面这种情况当你的城市很多的情况下 那这样就会出现大量的0 而系数矩阵只存储不是0的位置 可以节省大量空间 为什么采用这种…

中国算力网络铺开,竟是运营商走在前列?

明敏 发自 凹非寺量子位 | 公众号 QbitAI中国算力格局,已悄然发生改变。今年,在一批云厂商的积极布局下,一座座算力中心建成落地,坐标却纷纷绕开东南沿海和一线城市。成都、张北、乌兰察布、重庆……这种趋势概括起来就一句话&…

spring framework IoC 容器接口体系结构概述

目录BeanFactory体系结构BeanFactory 主要接口,可分为三级:BeanFactory 主要实现类:BeanFactory 相关接口和实现类:主要知识点ApplicationContext体系结构ApplicationContext 主要接口,可分为三级:二级接口…

[kerberos] kerberos 认证详解

什么是kerberos认证? kerberos 认证是一种用于验证通信双方身份的网络协议。即帮助客户端和服务端证明 我是我自己 ,从而使得通信双方可以完全信任对方身份 kerberos 角色组成? 客户端(client):发送请求的…

macOS/Linux如何开机自动挂载/卸载磁盘

不管是Linux还是基于Unix的macOS,挂载磁盘可以使用mount命令进行磁盘的挂载。 挂载的一般状态: 查看磁盘状态挂载磁盘读写磁盘 最后是卸载磁盘。 macOS和Windows类似,移动存储一般会自动挂载;部分Linux发行版本,也…

数据结构与算法(Java版) | 关于以上几个经典算法面试题的一个小结

为了让大家明白算法的重要性,以上我就举了几个经典的算法面试题,我的目的也很简单,就是希望引起大家对算法的一个兴趣。 之所以在正式讲解数据结构与算法之前引出这几个经典的算法面试题,是因为我想告诉大家如下三点。 算法非常…

一文看懂MySQL的explian执行计划

表: 数据: 例如:explain select * from t where a 2; 各个字段解释: select_type 表示查询中每个 select 子句的类型(简单 OR 复杂) type 对表的访问方式,表示 MySQL 在表中找到所需行的方式…

[DT框架使用教程01]如何在DT框架中创建插件

[DT框架使用教程01]如何在DT框架中创建插件 DT框架代码地址: https://github.com/huifeng-kooboo/DT 由于国内访问速度的问题 也可以访问gitee的地址: https://gitee.com/huifeng_github/DT DT框架是基于QT框架衍生出的组件化框架。 对于想具体了解DT框架的同学&…

GO语言基础介绍

go语言的GMP模型(协程并发模型),P是go语言本身内部实现的调度器,它是基于协程队列的,协程在调度器面前就类似一个个独立的任务;P一般数量上是处理器内核数。Process本身有调度和创建M的能力,它会…

Web3中文|迪士尼前任CEO回归,能否带领迪士尼开辟web3之路?

据国外媒体报道,11 月 21 日,当地时间周日晚间,迪士尼宣布首席执行官(CEO)鲍勃 查佩克(Bob Chapek)离职,而其前任鲍勃 伊格尔(Bob Iger)将重返迪士尼CEO一职…