每日八股-Redis篇-03

news/2024/12/2 17:54:51/

Redis事务

什么是事务?

事务是一个单独的隔离操作:事务中的所有命令都会序列化、按顺序执行。事务在执行的过程中,不会被其他客户端发送过来的命令请求打断。

事务是一个原子操作:事务中的命令要么全部被执行,要么全部都不执行。

Redis事务的概念

Redis事务的本质是通过MULTI、EXEC、WATCH等一组命令的集合。

事务支持一次性执行多个命令,一个事务中所有命令都会被序列化。在事务执行的过程中,会按照顺序串行化执行队列的命令,其他客户端提交的命令请求不会插入到事务执行命令序列中。

总结:Redis事务就是一次性、顺序性、排他性的执行一个队列中的一系列命令。

Redis事务的三个阶段

  • 事务开始 MULTI
  • 命令入队
  • 事务执行 EXEC

事务执行过程中,如果服务端收到有EXEC、DISCARD、WATCH、MULTI之外的请求,将会把请求放入队列中排队

Redis事务相关命令

Redis事务功能是通过MULTI、EXEC、DISCARD和WATCH四个原语实现的。

Redis会将一个事务中的所有命令序列化,然后按照顺序执行。

  • Redis不支持回滚,Redis在事务失败时不进行回滚,而是继续执行余下的命令,所以Redis的内部可以保持简单且快速。

  • 如果在一个事务中的命令出现问题,那么所有的命令都不会执行。

  • 如果在一个事务中出现运行错误,那么正确的命令将会被执行。

WATCH命令是一个乐观锁,可以为Redis事务提供check-and-set(CAS)行为。可以监控一个或多个键,一旦其中有一个键被修改(或删除),之后的事务就不会执行,监控一直持续到EXEC命令。UNWATCH命令可以取消watch对所有key的监控。

MULTI命令用于开启一个事务,它总是返回OK。MULTI执行后,客户端可以继续向服务器发送任意多条命了,这些命令不会立即被执行,而是被放到一个队列中,当EXEC命令被调用时,所有队列中的命令才会被执行。

EXEC命令执行所有事务块内的命令,返回事务块内所有命令的返回值,按命令执行的先后顺序排列,当操作被打断时,返回空值NULL。

DISCARD命令被调用时,客户端可以清空事务队列,并放弃执行事务,并且客户端会从事务状态中退出。

事务管理(ACID)概述

原子性(Atomicity):是指事务是一个不可分割的工作单位,事务中的操作要么全部都发生,要么都不发生。

一致性(Consistency):事务前后数据的完整性必须保持一致。

隔离性(Isolation):多个事务并发执行时,一个事务的执行不应影响其他事务的执行。

持久性(Durability):一个事务一旦被提交,它对数据库中数据的改变就是永久性的,接下来即使数据库发生故障也不应该对其有任何影响。

Redis的事务总是具有ACID中的一致性和隔离性,其他特性是不支持的,当服务器在AOF持久化模式下,并且appendfsync选项的值为always时,事务也具有持久性。

Redis事务支持隔离性吗?

Redis是单进程程序,并且它保持在执行事务时,不会对事务进行中断,事务可以运行直到执行完所有事务队列中的命令位置。因此,Redis的事物是总是带有隔离性的。

Redis事务保证原子性吗?支持回滚吗?

Redis中,单条命令是原子性执行的,但事务不保证原子性,且没有回滚。事务中任意命令执行失败,其余命令仍会被执行。

Redis事务其他实现

基于Lua脚本,Redis可以保证脚本内的命令一次性、按照顺序地执行,其同时也不提供事务运行错误的回滚,执行过程中如果部分命令运行错误,剩下的命令还是会继续运行完。

基于中间标记变量,通过另外的标记变量来标识事务是否执行完成,读取数据时先读取该标记变量判断是否事务执行完成。但这样需要额外写代码实现,比较繁琐。

如果您认为这篇文章对您有所帮助,希望能给我点一个免费的赞或收藏,这将是我创作的动力和鼓励!


http://www.ppmy.cn/news/165170.html

相关文章

单反使用知识

内容整理于网络 http://academy.fengniao.com/393/3935386_all.html http://dcdv.zol.com.cn/243/2430148_all.html 单反品牌和型号 大部分是佳能、尼康,几乎中低端市场全是这两品牌,另外还有索尼、奥林巴斯、宾得等。对于佳能,一位数D为专…

红米k50和k60参数对比哪个好 红米k50和k60区别

外观 在外观设计方面,两款手机其实差不多,红米K60的正面是一块直面屏,搭配塑料中框,后盖采用玻璃材质,提供了墨羽、晴雪、幽芒三种配色,还有一款素皮晴蓝,相比红米K50的质感更加丰富&#xff0c…

单反后键对焦的使用技巧

对于绝大部分同学来说,对焦时也会用上“半按快门”的动作,这个方法基本上很实用,能够把对焦到释放快门的功能放到同一颗按钮上,令拍摄更快速方便,但在一些时候半按快门来对焦并不适合,因此便有了“后键对焦…

view的常用属性和方法介绍(arcgis for javascript)

ArcGIS for JavaScript中的视图(view)是一个地图实例类,用于管理地图的显示区域、符号和标注等。通过视图类,可以实现以下功能: 显示地图:将地图显示在Web页面上。 缩放:缩放视图到指定的级别。…

安卓小游戏-俄罗斯方块

本应用通过Canvas绘图来实现. 定义int[][] matrix new int[32][20]的矩阵表示画面中的方格. 0表示该格为空,1表示该格正在下落.2表示该格已被填充. 在TerisView类中定义handler,间隔相同的时间,发送一次消息,执行down()方法,下落一格,让下落方块所在的区域的matrix[y][x]matr…

Android 俄罗斯方块

以前刚学安卓的时候花了大半天写出来的俄罗斯方块。 GitHub:GitHub - TTFlyzebra/Tetris 代码比较粗糙^-^,分享下代码:总共三个文件 1、TetriShape.java package com.flyzebra.tetris;import java.util.Random;public class TetriShape {/…

网页版俄罗斯方块

兼容性 兼容IE10&#xff0c;现代浏览器 效果图 项目结构 tetris   css     tetris.css   js     tetris.js   tetris.html tetris.html <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><tit…

俄罗斯方块

1. 案例介绍 俄罗斯方块是由 4 个小方块组成不同形状的板块&#xff0c;随机从屏幕上方落下&#xff0c;按方向键调整板块的位置和方向&#xff0c;在底部拼出完整的一行或几行。这些完整的横条会消失&#xff0c;给新落下来的板块腾出空间&#xff0c;并获得分数奖励。没有被…