热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

第19章事务

把多个Redis命令放到队列中,一次性执行队列里的所有命令。整个过程分为三个阶段:1、事务开始2、命令入队3、命令执行19.1.1事务开始做了什么:改变Redis服务端的状态,把R

  把多个Redis命令放到队列中,一次性执行队列里的所有命令。整个过程分为三个阶段:1、事务开始 2、命令入队 3、命令执行

19.1.1 事务开始

  做了什么:改变Redis服务端的状态,把Redis服务端的状态由非事务状态切换到事务状态,非事务状态会立即响应并执行客户端的请求,事务状态下会把Redis请求放入队列里并返回QUEUED,代表已经把指令放入队列。

19.1.2 命令入队

  第19章 事务

 

第19章 事务

19.1.3 事务队列

  事务队列维护一个队列,该队列里保存所有在事务状态下已经接受但还未执行并返回的指令。

19.1.4 执行事务

  当处于事务状态下的Redis服务端接收到EXEC指令后会执行事务队列里的指令并返回。

  第19章 事务

 

19.2 WATCH命令

  WATCH是一种乐观锁,之所以称为乐观锁是因为他并没有强制保证WATCH的键不会被修改,它只是在发现WATCH的对象被别的线程修改后拒绝执行事务。与乐观锁相对应的是分布式锁,分布式锁是一种悲观锁。只有在MUTI命令之前执行WATCH才有效,MUTI后执行WATCH会报错。

第19章 事务

  客户端B修改了name,name在客户端A开启的事务中,当服务端EXEC客户端A的事务队列时,发现name被修改,拒绝执行客户端A的事务队列。

 19.2.1 WATCH简单实现原理

  Redis服务端维护一个watch_dict,保存所有被监视的key以及监视这些key的客户端ID。下面这张图代表c1 c2客户端监视了name。

第19章 事务

  所有对数据库进行修改的命令执行完毕后都会检查watched_key。如某个线程修改了name字段,该线程会根据watched_dict找到c1 c2监视name,并打开c1 c2的REDIS_DIRTY_CAS标识,该标识被打开代表该客户端事务安全性被破坏。

  当Redis服务端执行某个客户端的EXEC命令时,会先检查 REDIS_DIRTY_CAS标识,只有在该标识没有被打开的情况下才会执行该客户端的事务。

 

19.3 事务的ACID

  Redis事务具有ACI性质,在某种特定持久化模式下也具有D。

19.3.1 原子性

  关于原子性,该书给出的结论是:Redis事务的原子性是一种不具有回滚功能的特殊的原子性。虽然特殊但是也具有原子性。原子性的关键在于一个事务中如果有一个语句执行失败,数据库是否会回滚之前已经成功执行的语句。就Redis而言,分为两种情况:

1、Redis命令在加入事务队列前发现错误,此时会“回滚”,之所以加上引号是因为这并不是回滚,因为当事务中一个命令加入Redis事务队列失败后,整个事物队列都不会执行。比如下面的例子,首先把正确的指令加入事务队列,然后把错误的get指令加入事务队列,此时报错,因为这不符合get指令的语法要求,所以当执行EXEC的时候也报错,最后检查test发现没有赋值成功。

  第19章 事务

2、Redis命令加入事务队列不报错,不回滚。

  在事务外面执行set test 456,test为字符串类型。然后开启事务,先执行set a 123,这条指令是正确的。然后执行lpush test 1 2 3 4,这条指令是错误的,因为test已经被设置成了字符串类型。随后执行EXEC,不出意外的报错。虽然执行EXEC报错,但是检查最后的结果发现a被设置成了123,说明在一个事务中,一条执行执行,一条没有执行,你告诉我这是原子性????

  第19章 事务

  总之,最后总结发言

  • 加入事务队列的时候发现指令错误,整个事务队列里所有指令都不会执行,此时的Redis事务是具有原子性的。这种错误被称为入队错误
  • 已经加入事务队列,但该指令是错误的。当EXEC执行整个事务的时候,所有正确的指令会执行并产生影响,错误的指令不被执行。且已经执行的正确指令不会回滚。这种错误被称为执行错误

19.3.2 一致性

  根据原子性的分析,Redis不具有一致性。

 

19.3.3 隔离性

  Redis是单线程模型,不会出现并发问题,且Redis保证事务执行过程中不会被打断,因此Redis具有隔离性。

19.3.4 永久性

  Redis的事务只是简单的把多个命令放在队列里执行,并不会对持久化造成影响,所以事务的持久性取决于Redis本身的持久性

  • 不开启任何持久化配置的情况下,Redis不具有耐久性,掉电即失。
  • 只开启RDB持久化,在不显示执行SAVE命令时,两次BGSAVE之间的数据会丢失
  • 开启AOF持久化,取决于同步写(appendsync)命令的配置,always下,不会丢失数据,具有持久性;everysec下,最多丢失一秒的诗句,no下,丢失的数据取决于操作系统

 


推荐阅读
  • Tomcat/Jetty为何选择扩展线程池而不是使用JDK原生线程池?
    本文探讨了Tomcat和Jetty选择扩展线程池而不是使用JDK原生线程池的原因。通过比较IO密集型任务和CPU密集型任务的特点,解释了为何Tomcat和Jetty需要扩展线程池来提高并发度和任务处理速度。同时,介绍了JDK原生线程池的工作流程。 ... [详细]
  • 李逍遥寻找仙药的迷阵之旅
    本文讲述了少年李逍遥为了救治婶婶的病情,前往仙灵岛寻找仙药的故事。他需要穿越一个由M×N个方格组成的迷阵,有些方格内有怪物,有些方格是安全的。李逍遥需要避开有怪物的方格,并经过最少的方格,找到仙药。在寻找的过程中,他还会遇到神秘人物。本文提供了一个迷阵样例及李逍遥找到仙药的路线。 ... [详细]
  • 2018年人工智能大数据的爆发,学Java还是Python?
    本文介绍了2018年人工智能大数据的爆发以及学习Java和Python的相关知识。在人工智能和大数据时代,Java和Python这两门编程语言都很优秀且火爆。选择学习哪门语言要根据个人兴趣爱好来决定。Python是一门拥有简洁语法的高级编程语言,容易上手。其特色之一是强制使用空白符作为语句缩进,使得新手可以快速上手。目前,Python在人工智能领域有着广泛的应用。如果对Java、Python或大数据感兴趣,欢迎加入qq群458345782。 ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • 本文介绍了Python高级网络编程及TCP/IP协议簇的OSI七层模型。首先简单介绍了七层模型的各层及其封装解封装过程。然后讨论了程序开发中涉及到的网络通信内容,主要包括TCP协议、UDP协议和IPV4协议。最后还介绍了socket编程、聊天socket实现、远程执行命令、上传文件、socketserver及其源码分析等相关内容。 ... [详细]
  • 基于layUI的图片上传前预览功能的2种实现方式
    本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • 本文讨论了使用差分约束系统求解House Man跳跃问题的思路与方法。给定一组不同高度,要求从最低点跳跃到最高点,每次跳跃的距离不超过D,并且不能改变给定的顺序。通过建立差分约束系统,将问题转化为图的建立和查询距离的问题。文章详细介绍了建立约束条件的方法,并使用SPFA算法判环并输出结果。同时还讨论了建边方向和跳跃顺序的关系。 ... [详细]
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • 本文由编程笔记小编整理,介绍了PHP中的MySQL函数库及其常用函数,包括mysql_connect、mysql_error、mysql_select_db、mysql_query、mysql_affected_row、mysql_close等。希望对读者有一定的参考价值。 ... [详细]
  • 本文介绍了Oracle数据库中tnsnames.ora文件的作用和配置方法。tnsnames.ora文件在数据库启动过程中会被读取,用于解析LOCAL_LISTENER,并且与侦听无关。文章还提供了配置LOCAL_LISTENER和1522端口的示例,并展示了listener.ora文件的内容。 ... [详细]
  • Redis底层数据结构之压缩列表的介绍及实现原理
    本文介绍了Redis底层数据结构之压缩列表的概念、实现原理以及使用场景。压缩列表是Redis为了节约内存而开发的一种顺序数据结构,由特殊编码的连续内存块组成。文章详细解释了压缩列表的构成和各个属性的含义,以及如何通过指针来计算表尾节点的地址。压缩列表适用于列表键和哈希键中只包含少量小整数值和短字符串的情况。通过使用压缩列表,可以有效减少内存占用,提升Redis的性能。 ... [详细]
  • 在编写业务代码时,常常会遇到复杂的业务逻辑导致代码冗长混乱的情况。为了解决这个问题,可以利用中间件模式来简化代码逻辑。中间件模式可以帮助我们更好地设计架构和代码,提高代码质量。本文介绍了中间件模式的基本概念和用法。 ... [详细]
  • 本文介绍了一道网络流题目hdu4888 Redraw Beautiful Drawings的解题思路。题目要求以行和列作为结点建图,并通过最大流算法判断是否有解以及是否唯一。文章详细介绍了建图和算法的过程,并强调在dfs过程中要进行回溯。 ... [详细]
author-avatar
mobiledu2502853033
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有