Redis事务深入解析

Redis 事务介绍

  1. Redis 的事务是通过 MULTI,EXEC,DISCARD 和 WATCH 这四个命令来完成的。
  2. Redis 的单个命令都是原子性的,所以这里确保事务性的对象是命令集合。
  3. Redis 将命令集合序列化并确保处于同一事务的命令集合连续且不被打断的执行
  4. Redis不支持回滚操作

相关命令

image.png

在介绍 Redis 事务相关命令前,我们先上一张图,这张图很好的描述了 Redis 事务的执行过程,在图里体现了部分命令,WATCH 命令会在后面单独介绍,需要注意的一点是这张图里面的 queue 队列,理解它的作用,然后再结合相关命令的介绍,就能够很快搞明白 Redis 事务。

1)MULTI:用于标记事务块的开始。Redis 会将后续的命令逐个放入队列中,然后使用 EXEC 命令原子化地执行这个命令序列。

127.0.0.1:6379> multi # 开启事务
OK
127.0.0.1:6379> set k1 alan # 设置 k1
QUEUED # k1 加入队列
127.0.0.1:6379> set k2 tom # 设置 k2
QUEUED # k2 加入队列

2)EXEC:在一个事务中执行所有先前放入队列的命令,然后恢复正常的连接状态。

127.0.0.1:6379> exec
1) OK
2) OK

使用 EXEC 命令原子化地执行这个命令序列,刚刚我们设置了 k1 和 k2 两条命令,执行EXEC 命令后,给我们反馈了两个 OK,说明上述两条命令全部执行成功。

3)DISCARD:清除所有先前在一个事务中放入队列的命令,然后恢复正常的连接状态。

127.0.0.1:6379> multi
OK
127.0.0.1:6379> set k3 lucy
QUEUED
127.0.0.1:6379> set k4 jack
QUEUED
127.0.0.1:6379> discard
OK

4)WATCH:当某个事务需要按条件执行时,就要使用这个命令将给定的键设置为受监控的状态。注意:使用该命令可以实现 Redis 的乐观锁。

(1)对于 WATCH 命令的演示就稍微麻烦一些,这里我们在 Xshell 中开启两个 ssh 渠道,并且都连接到了单机的 Redis 服务(两个 ssh 渠道连接的是同一个 Redis 服务)


在这里插入图片描述

(2)在第一个窗口中使用 WATCH 命令,监控 data1,并开启事务,添加设置 data2 的命令到命令队列中


在这里插入图片描述

(3)然后在第二个窗口中,改变 data1 的值


在这里插入图片描述

(4)回到第一个窗口,执行 EXEC 命令,此时会发现返回了一个 nil,而且我们获取 data2 的值,返回的也是 nil,这就说明,当被监控的数据发生改变后,开启的事务执行是无法成功的,只有被监控的数据不发生变化,事务才能正常执行。
在这里插入图片描述

5)UNWATCH:清除所有先前为一个事务监控的键。

3、事务失败处理

1)Redis 语法错误(可以理解为编译期错误)


在这里插入图片描述

在一个事务中,当命令出现错误时,后续命令正确依旧是可以添加到命令队列中去得,但是使用 EXEC 命令执行命令队列的时候,就会报错,并且队列中正确的命令也不会被执行。

2)Redis 类型错误(可以理解为运行期错误)
在这里插入图片描述

这种错误不是命令错误,而是因为对命令理解不透彻出现的使用错误,在执行过程中会报错,因为 username1 不是 list 类型,它只是一个 string 类型。有一点需要注意,从结果可以看出,第一条命令是执行成功了的,所有我们使用"get username1"命令,返回了"alan"结果,这也证明了 Redis 是不支持事务回滚的。

3)为什么 Redis 不支持事务回滚?

(1)大多数事务失败是因为语法错误或者类型错误,这两种错误,在开发阶段都是可以预见的。

(2)Redis 为了性能方面就忽略了事务回滚。

Linux、C/C++技术交流群:整理了一些C/C++ Linux服务器架构师学习资料(加群获取)(资料包括C/C++,Linux,golang技术,Nginx,ZeroMQ,MySQL,Redis,fastdfs,MongoDB,ZK,流媒体,CDN,P2P,K8S,Docker,TCP/IP,协程,DPDK,ffmpeg等),免费分享

在这里插入图片描述

想要搞明白 Redis 事务,一定要先理解文中那张图解,了解 queue 命令队列,以及各个命令是如何操作命令队列的,还要特别注意 WATCH 命令,了解它的运行原理以及使用场景,最为重要的是一定要知道 Redis 事务失败后是如何处理的,分为了两种情况,还要能说明为什么 Redis 是不支持事务回滚的,了解了这些东西就 OK 了。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,029评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,395评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,570评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,535评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,650评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,850评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,006评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,747评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,207评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,536评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,683评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,342评论 4 330
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,964评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,772评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,004评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,401评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,566评论 2 349

推荐阅读更多精彩内容