【Redis】聊一下Redis事务以及watch机制

news2025/1/8 5:50:26

我们知道熟悉MySQL的同学,一定了解ACID属性。ACID分别对应四种属性,但是Redis的事务和ACID属性有什么不一样的地方嘛,我们来深入探讨下。

Redis事务和MySQL事务的区别

ACID的本质是保证了事务执行前后对结果的保证,以及数据状态变化的保证。MySQL通过日志、MVCC、隔离级别、锁等机制实现ACID。
但是Redis并不是传统意义上的事务级别,Redis的事务本质是可以一次执行多条命令、并且在这个事务中会序列化执行,按照顺序串行化执行而不会被其他命令插入,不许加塞。

Redis事务原理

具体命令
在这里插入图片描述
执行流程

  • 1.客户端会显示的使用MULTI声明事务开始,
  • 2.客户端发送对数据的操作,增删改查,然后Redis服务端接受之后会暂存到一个命令队列中,这个时候并不会执行。
  • 3.当客户端发送EXEC命令之后,服务端会从命令队列中按照顺序取出来,执行。

正常执行

127.0.0.1:6379> MULTI 
OK
127.0.0.1:6379(TX)> set key1 v1
QUEUED
127.0.0.1:6379(TX)> set key2 v2
QUEUED
127.0.0.1:6379(TX)> EXEC
1) OK
2) OK

原子性

上面在正常的情况下,MUTI 和 EXEC 都会被正常执行可以保证原子性。
1.在提交命令的时候,如果命令本身就是错误的
显然执行之后,直接抛出错误,可以保证原子性

127.0.0.1:6379> MULTI 
OK
127.0.0.1:6379(TX)> put het 1
(error) ERR unknown command `put`, with args beginning with: `het`, `1`, 
127.0.0.1:6379(TX)> set key3 v3
QUEUED
127.0.0.1:6379(TX)> EXEC
(error) EXECABORT Transaction discarded because of previous errors.
127.0.0.1:6379> 

2.提交命令时,命令和数据类型不符合,在执行的时候异常
在对key1 进行减1操作的时候执行出错,但是后续的命令却成功了,显然这没有保证原子性。属于一半执行成功,一半执行失败。
在MySQL中,提供了回滚操作,但是在Redis中虽然提供了DISCARD 主动放弃事务,把命令队列清空,起不到数据回滚的作用。

127.0.0.1:6379> MULTI
OK
127.0.0.1:6379(TX)> DECR key1
QUEUED
127.0.0.1:6379(TX)> set key6 v6
QUEUED
127.0.0.1:6379(TX)> EXEC
1) (error) ERR value is not an integer or out of range
2) OK
127.0.0.1:6379> 

3.在执行事务exec Redis实例发生了故障,导致事务执行失败
如果Redis故障了,我们开启了AOF机制,那么可以通过AOF恢复实例宕机之前的数据,但是如果没有开启,无法保证原子性。

  • 命令入队就出错的话,会放弃整个事务,可以保证原子性。
  • 命令入队在执行的时候出错的话,不保证原子性
  • EXEC命令执行故障,开启AOF日志,可以保证原子性。

一致性

数据一致性其实就在执行前后,是否会保证数据状态的一致性,而上述原子性中,可以发现,出了对出现错误的命令不会执行,剩下情况其实是可以保证数据一致性的。

隔离性

事务的隔离性与事务并发修改数据有关系,而事务执行时机又可以分为命令入队(EXEC执行前),命令执行后(EXEC执行后)

  • 并发操作在EXEC执行前,需要使用WATCH机制进行保证,否则隔离性无法保证。
  • 并发操作在EXEC执行后,隔离性可以保证。

第一种情况
我们知道当命令在队列中时,是没有执行命令,这个时候如果有别的线程修改对应的队列中命令字段对应的数据值,就无法保证隔离性。但是使用WATCH机制可以保证,WATCH机制的原理是通过在命令入队之前,监控对应的键是否修改,如果修改,那么在EXEC执行时就会异常。
在这里插入图片描述
具体就是EXEC值执行发现WATCH监听的数据有修改,就是放弃执行。但是如果没有WTCH机制,exec队列中命令也会读取最新的值,但是这样其实没有办法保证隔离性。

第二种方式,exec执行之后
因为redis是单线程执行,所以会先保证把命令队列中所有命令执行完,所以这种方式也不会破坏事务的隔离性。
在这里插入图片描述

持久性

持久性其实就依赖于Redis的AOF和RDB机制,而不同的持久化方式,也无法完全百分百保证数据一定会被持久化,RDB有一定的频率执行,而Redis虽然可以使用always模式,但是如果正好写入内存的数据没有刷到pageCache中,也没有办法进行数据持久化。

总结

本篇主要介绍了Redis的事务在ACID中不同的实现,综合分析,我们可以得出一个结论,Redis事务只保证了一致性和隔离性,但是无法保证持久性,并且Redis是一个缓存中间件,大多数的时候,业务上其实可以容许出现数据丢失的情况。
在这里插入图片描述

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

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

相关文章

二、数据结构2:双链表 模板题+算法模板(双链表)

文章目录 算法模板双链表题目模板 模板题双链表原题链接题目思路题解 算法模板 双链表题目模板 // e[]表示节点的值,l[]表示节点的左指针,r[]表示节点的右指针,idx表示当前用到了哪个节点 int e[N], l[N], r[N], idx;// 初始化 void init()…

Android进阶 View事件体系(一):概要介绍和实现View的滑动

Android进阶 View事件体系(一):概要介绍和实现View的滑动 内容概要 本篇文章为总结View事件体系的第一篇文章,将介绍的内容主要有: 什么是View和ViewGroupAndroid中View的坐标轴手势检测和速度检测如何实现View的滑动…

【ZYNQ】ZYNQ7000 UART 控制器及驱动应用示例

UART 简介 我们在使用 PS 的时候,通常会添加 UART 控制器,用于打印信息和调试代码。除此之外,PS 在和外 部设备通信时,也会经常使用串口进行通信。 UART 控制器 UART 控制器是一个全双工异步收发控制器,ZYNQ 内部包…

ssm实现发送邮箱功能

参考:ssm整合JavaMail发送邮件_ssm整合mimemessage_ds_surk的博客-CSDN博客 我在这位前辈写的博客的基础上进行讲解完善,避免踩坑。 我的jdk版本:1.8.0_333 1、引入依赖 相信很多朋友都卡在这里: 1、没有JavaMailSenderImpl类 2、…

数字逻辑 期末

概述 教材:《电子技术基础(数字部分)》 第五版 7400系列是TTL型芯片,商用型 数制 十进制->二进制 除2取余法&乘2取整法(注意精度,但计科简单不考) 十六进制->二进制 一位变四位 八…

Linux下串口编程

Linux下串口编程 Linux下的串口编程是通过串口设备文件和串口通信的系统调用函数来实现的。Linux下的串口设备文件通常为/dev/ttyS或/dev/ttyUSB(*表示数字),这些设备文件代表了对应的串口硬件设备。 在进行串口编程之前,需要先打开并初始化串口设备,其中包括设置波特率…

Linux 在桌面添加快捷启动图标(可添加至收藏夹)

0 背景 在 Ubuntu 系统下启动程序一般在 Terminal 通过输入指令启动,如 ./cfw。对于常用的程序,为了方便,创建桌面快捷图标 .desktop。为了让图标能够添加在收藏栏中,将 .desktop 融入桌面环境。 1 创建 .desktop 文件 参考&…

dvwa靶场通关(一)

第一关:Brute force low 账号是admin,密码随便输入 用burp suite抓包 爆破得出密码为password 登录成功 Medium 中级跟low级别基本一致,分析源代码我们发现medium采用了符号转义,一定程度上防止了sql注入,采用暴力破…

如何成为一名黑客?小白必学的12个基本步骤

黑客攻防是一个极具魅力的技术领域,但成为一名黑客毫无疑问也并不容易。你必须拥有对新技术的好奇心和积极的学习态度,具备很深的计算机系统、编程语言和操作系统知识,并乐意不断地去学习和进步。 如果你想成为一名优秀的黑客,下…

大项目参考地址​编辑 大项目接口实现

目录 大项目参考地址​编辑 口语考试 纸笔口语考试通常会安排在笔试前一周至笔试后一周的任意一天,机考口语考试通常会安排在笔试当天或者与笔试日期尽可能相邻的日期。根据考务安排的需要,在特殊情况下,口试日期有可能超出此区间&#xff0…

Java——《面试题——多线程并发篇》

前文 java——《面试题——基础篇》 Java——《面试题——JVM篇》 目录 前文 1、说说Java中实现多线程有几种方法 2、如何停止一个正在运行的线程 3、notify()和notifyAll()有什么区别? 4、sleep()和wait() 有什么区别? 5、volatile 是什么?可…

nodejs+vue网络课程在线考试系统an7ib

在线考试系统的设计与实现主要实现角色有管理员和用户,管理员在后台管理学生模块、用户表模块、token表模块、考试资讯模块、考试记录表模块、试题表模块、试卷表模块、配置文件模块、在线答疑模块 采用了Windows10操作系统平台,使用vue前端模板node作为后台监控&am…

k8s补充+helm(待续)

目录 master高可用架构master节点——整个集群的控制中枢node节点——工作节点搭建kubeadm搭建二进制搭建 探针检测方式探针检查参数配置执行顺序为什么有了livenessProbe和readnessProbe还要有StartupProbe(1.16) 零宕机发布pod退出流程preStop 无状态服…

上网速度太慢?这样设置可以提升60%的上网速度!

虽然现在光纤上网是最好的上网方式,但是对于一般人的选择还是宽带上网,网速永远都是一个值得讨论的话题。花了那么多的钱,却得到的是低品质的网速服务,因此越来越多的人想方设法在现有条件上提高网速。网上的那些方法基本人人都会…

手把手教你用Python编写配置脚本引擎(福利篇)

版权声明:原创不易,本文禁止抄袭、转载需附上链接,侵权必究! 目录 一、配置信息写入二、读取配置信息三、修改配置信息四、配置引擎总结五、作者Info 一、配置信息写入 配置信息初始化 定义配置引擎类和初始化方法,其…

day18文件上传下载与三层架构思想

servlet文件上传 注意事项:在写了响应后,若后面还需要执行代码,需要添加return; apach的servlet3.0提供了文件上传的功能. **在客户端中的jsp如何上传文件:**使用form标签 使用input标签type的file属性 form表单中的的enctype必须加:使用二进制的方式进行传输,否则不能进行…

day20 过滤器和监听器

过滤器Filter 作用:对请求和响应进行预处理 使用场景:字符编码处理,登录检验,敏感词过滤,前端框架分发器 Filter的开发步骤 filter也是一个web组件,结构和servlet相似 1.定义类:实现javax.servlet.Filter接口 2.覆盖里面的3个方法: innit:初始化 doFilter:对请求和响应…

线程池C和C++实现

一、线程池介绍 1)应用场景 当并发数很多的时候,并且每个线程执行时间很短的任务,这样就会频繁创建线程,而这样的频繁创建和销毁线程会大大降低系统的执行效率。对于这种场景我们可以使用线程池来复用之前创建的线程&#xff0c…

Java 与排序算法(7):堆排序

一、堆排序 堆排序是一种基于比较的排序算法,它的基本思想是将待排序的元素构建成一个堆,然后依次将堆顶元素取出,放到已排序的序列中,直到堆中所有元素都被取出,最终得到一个有序的序列。 堆是一种特殊的树形数据结…

5.24 基础题目

快速幂 #include<bits/stdc.h> using namespace std; //126348976 982638476 938420413 int main(){int a,b,p;cin>>a>>b>>p;long long res 1,ci1;int flag0;if(b0){res%p;}else{while(b){if (flag0)cia%p;elseci(ci%p)*(ci%p)%p;if (b&1)res(res…