热门标签 | 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下,丢失的数据取决于操作系统

 


推荐阅读
  • 深入理解 SQL 视图、存储过程与事务
    本文详细介绍了SQL中的视图、存储过程和事务的概念及应用。视图为用户提供了一种灵活的数据查询方式,存储过程则封装了复杂的SQL逻辑,而事务确保了数据库操作的完整性和一致性。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 优化Flask应用的并发处理:解决Mysql连接过多问题
    本文探讨了在Flask应用中通过优化后端架构来应对高并发请求,特别是针对Mysql 'too many connections' 错误的解决方案。我们将介绍如何利用Redis缓存、Gunicorn多进程和Celery异步任务队列来提升系统的性能和稳定性。 ... [详细]
  • 本文深入探讨了MySQL中常见的面试问题,包括事务隔离级别、存储引擎选择、索引结构及优化等关键知识点。通过详细解析,帮助读者在面对BAT等大厂面试时更加从容。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • Redis Hash 数据结构详解
    本文详细介绍了 Redis 中的 Hash 数据类型及其常用命令。Hash 类型用于存储键值对集合,支持多种操作如插入、查询、更新和删除字段值。此外,文章还探讨了 Hash 类型在实际业务场景中的应用,并提供了优化建议。 ... [详细]
  • 本文介绍了数据库体系的基础知识,涵盖关系型数据库(如MySQL)和非关系型数据库(如MongoDB)的基本操作及高级功能。通过三个阶段的学习路径——基础、优化和部署,帮助读者全面掌握数据库的使用和管理。 ... [详细]
  • 深入解析Java多线程与并发库的应用:空中网实习生面试题详解
    本文详细探讨了Java多线程与并发库的高级应用,结合空中网在挑选实习生时的面试题目,深入分析了相关技术要点和实现细节。文章通过具体的代码示例展示了如何使用Semaphore和SynchronousQueue来管理线程同步和任务调度。 ... [详细]
  • PHP 编程疑难解析与知识点汇总
    本文详细解答了 PHP 编程中的常见问题,并提供了丰富的代码示例和解决方案,帮助开发者更好地理解和应用 PHP 知识。 ... [详细]
  • 深入理解OAuth认证机制
    本文介绍了OAuth认证协议的核心概念及其工作原理。OAuth是一种开放标准,旨在为第三方应用提供安全的用户资源访问授权,同时确保用户的账户信息(如用户名和密码)不会暴露给第三方。 ... [详细]
  • Python 异步编程:深入理解 asyncio 库(上)
    本文介绍了 Python 3.4 版本引入的标准库 asyncio,该库为异步 IO 提供了强大的支持。我们将探讨为什么需要 asyncio,以及它如何简化并发编程的复杂性,并详细介绍其核心概念和使用方法。 ... [详细]
  • 在计算机技术的学习道路上,51CTO学院以其专业性和专注度给我留下了深刻印象。从2012年接触计算机到2014年开始系统学习网络技术和安全领域,51CTO学院始终是我信赖的学习平台。 ... [详细]
  • 深入探讨CPU虚拟化与KVM内存管理
    本文详细介绍了现代服务器架构中的CPU虚拟化技术,包括SMP、NUMA和MPP三种多处理器结构,并深入探讨了KVM的内存虚拟化机制。通过对比不同架构的特点和应用场景,帮助读者理解如何选择最适合的架构以优化性能。 ... [详细]
  • 本题探讨如何通过最大流算法解决农场排水系统的设计问题。题目要求计算从水源点到汇合点的最大水流速率,使用经典的EK(Edmonds-Karp)和Dinic算法进行求解。 ... [详细]
  • 微软Exchange服务器遭遇2022年版“千年虫”漏洞
    微软Exchange服务器在新年伊始遭遇了一个类似于‘千年虫’的日期处理漏洞,导致邮件传输受阻。该问题主要影响配置了FIP-FS恶意软件引擎的Exchange 2016和2019版本。 ... [详细]
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社区 版权所有