IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> Redis——事务操作 -> 正文阅读

[大数据]Redis——事务操作

📢📢📢📣📣📣?

哈喽!大家好,我是【一心同学】,一位上进心十足的【Java领域博主】!😜😜😜

?【一心同学】的写作风格:喜欢用【通俗易懂】的文笔去讲解每一个知识点,而不喜欢用【高大上】的官方陈述。

?【一心同学】博客的领域是【面向后端技术】的学习,未来会持续更新更多的【后端技术】以及【学习心得】。

?如果有对【后端技术】感兴趣的【小可爱】,欢迎关注一心同学】💞💞💞

??????感谢各位大可爱小可爱!???????


目录

一、Redis事务介绍

二、Redis事务三大保证

三、基本命令

四、场景演示

🌴 正常执行事务

🌴 取消事务

🌵 编译型异常

🌵 运行时异常

五、监控

🌴 正常执行场景

🌵 异常执行

小结


一、Redis事务介绍

关系型数据库中的事务是原子性的,但作为非关系型数据库的Redis的事务是非原子性的,原子性就是整个程序中的所有操作,要么全部完成,要不全部不完成。也就是说在我们的Redis事务中,我们执行了操作A,操作B,如果操作A失败,另一个表仍然会继续执行,事务不会回滚(对于关系型数据库不会出现非原子性)。

一个事务从开始到执行会经历以下三个阶段:

  • 开始事务。
  • 命令入队。
  • 执行事务。

二、Redis事务三大保证

Redis 事务可以一次执行多个命令, 并且带有以下三个重要的保证:
(1)批量操作在发送 EXEC 命令前被放入队列缓存。
(2)收到 EXEC 命令后进入事务执行,事务中任意命令执行失败,其余的命令依然被执行。(除了编译型异常)
(3)在事务执行过程,其他客户端提交的命令请求不会插入到事务执行命令序列中。

🔥?注意

🚀?Redis事务没有没有隔离级别的概念。

🚀?所有的命令在事务中,并没有直接被执行,只有发起执行命令Exec的时候才会执行

🚀?Redis单条命令式保存原子性的,但是事务不保证原子性

三、基本命令

序号命令及描述
1?DISCARD
取消事务,放弃执行事务块内的所有命令。?
2?EXEC
执行所有事务块内的命令。?
3?MULTI
标记一个事务块的开始。?
4?UNWATCH
取消 WATCH 命令对所有 key 的监视。?
5?WATCH key [key ...]
监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断。?

四、场景演示

🌴 正常执行事务

127.0.0.1:6379> multi  #开启事务
OK
#命令入队
127.0.0.1:6379> set k1 v1
QUEUED
127.0.0.1:6379> set k2 v2
QUEUED
127.0.0.1:6379> get k2
QUEUED
127.0.0.1:6379> exec    #执行事务
1) OK
2) OK
3) "v2"

🌴 取消事务

127.0.0.1:6379> multi    #开启事务
OK
127.0.0.1:6379> set k1 v1
QUEUED
127.0.0.1:6379> set k2 v2
QUEUED
127.0.0.1:6379> discard    #取消事务
OK
127.0.0.1:6379> get k1    #事务队列中命令都不会被执行
(nil)

🌵 编译型异常

Tip:代码或命令行写错,事务中的所有命令都不会执行

127.0.0.1:6379> multi    #开启事务
OK
#命令入队
127.0.0.1:6379> set k1 v1
QUEUED
127.0.0.1:6379> set k2 v2
QUEUED
127.0.0.1:6379> getxxx k3    #错误命令
(error) ERR unknown command `getxxx`, with args beginning with: `k3`, 
127.0.0.1:6379> set k4 v4
QUEUED
127.0.0.1:6379> exec    #执行事务报错
(error) EXECABORT Transaction discarded because of previous errors.
127.0.0.1:6379> get k4    #所有的命令都不会被执行
(nil)

🌵 运行时异常

Tip: 例如1/0这种错误,如果事务队列中某个操作存在运行时异常问题,那么执行命令的时候,其他命令是可以正常执行的,错误命令抛出异常

127.0.0.1:6379> set k1 'v1'
OK
127.0.0.1:6379> multi    #开启事务
OK
127.0.0.1:6379> incr k1    #对字符串执行自增操作
QUEUED
127.0.0.1:6379> set k2 v2
QUEUED
127.0.0.1:6379> get k2
QUEUED
127.0.0.1:6379> exec    #执行事务
#虽然第一条命令报错了,但是依旧正常执行成功
1) (error) ERR value is not an integer or out of range
2) OK
3) "v2"

五、监控

Tip:进行监控一个数据,一直到事务结束,如果这个数据没有被其它线程改动,那么就执行成功。

🌴 正常执行场景

我们来模拟一个转账的例子,yixin向zhangsan转账20块。

127.0.0.1:6379> set money_yixin 100
OK
127.0.0.1:6379> set money_zhangsan 50
OK
127.0.0.1:6379> watch money_yixin    #监控money_yixin这个对象
OK
127.0.0.1:6379> multi    #开启事务
OK
127.0.0.1:6379> decrby money_yixin 20
QUEUED
127.0.0.1:6379> incrby money_zhangsan 20
QUEUED
127.0.0.1:6379> exec    #在这个事务期间,money_yixin的数据没有被其它线程影响到,执行成功。
1) (integer) 80
2) (integer) 70

🌵 异常执行

Tip:当我们所要监控的数据被其它线程修改了,那么在这个事务就无法正常执行

线程一:

127.0.0.1:6379> set money_yixin 100
OK
127.0.0.1:6379> set money_zhangsan 50
OK
127.0.0.1:6379> watch money_yixin    #监控money_yixin
OK
127.0.0.1:6379> multi    #开启事务
OK
127.0.0.1:6379> decrby money_yixin 20
QUEUED
127.0.0.1:6379> incrby money_zhangsan 20
QUEUED

注意:这个时候我们还没提交,我们进入第二个线程对money_yixin进行修改。

线程二:

127.0.0.1:6379> get money_yixin   #此时线程一的事务还没执行,所有还是100
"100"
127.0.0.1:6379> decrby money_yixin 30    #对被监控的数据进行修改
(integer) 70

那么这个时候我们对线程一进行事务执行操作,由于线程二修改了我们监控的值,所以会导致事务执行失败!

解决方案

对于这种情况,我们需要先使用命令UNWATCH进行解除监控,获取最新的值再次监控即可

127.0.0.1:6379> unwatch    #解除监控,获取最新数据
OK
127.0.0.1:6379> watch money_yixin
OK
127.0.0.1:6379> multi    #开启事务
OK
127.0.0.1:6379> decrby money_yixin 20
QUEUED
127.0.0.1:6379> incrby money_zhangsan 20
QUEUED
127.0.0.1:6379> exec    #执行事务
1) (integer) 50
2) (integer) 70

?现在,请让【一心同学】扔出一张图,看完相信大家就能够清楚Redis中的事务操作了!


小结

以上就是【一心同学】对【Redis】中的【事务操作】讲解了,我们要记住【Redis】中的事物操作是【非原子性】的,这个概念【非常重要】,大家也可以自动动手跟着【一心同学】的思路敲一遍代码,相信就能更快的理解了。

如果这篇【文章】有帮助到你,希望可以给【一心同学】点个👍,创作不易,相比官方的陈述,我更喜欢用【通俗易懂】的文笔去讲解每一个知识点,如果有对【后端技术】感兴趣的小可爱,也欢迎关注???????【一心同学】??????,我将会给你带来巨大的【收获与惊喜】💕💕!

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-02-24 15:21:56  更:2022-02-24 15:22:08 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/17 0:16:15-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码