ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

Redis中事务

2022-02-03 11:31:43  阅读:160  来源: 互联网

标签:事务 命令 队列 Redis 组队 执行


目录

1 概述

2 事务相关操作 

2.1 Multi、Exec、discard

 2.2 事务的错误处理

3 如何解决事务冲突

4 Redis事务的三特性



1 概述

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

        Redis事务中的主要作用是串联多个命令防止别的命令插队        

2 事务相关操作 

2.1 Multi、Exec、discard

从输入Multi开始,就相当于开启了事务,输入的事务都会依次进入到命令队列中,但不会执行,直到输入Exec后,Redis会将之前命令中的队列依次执行。

组队过程中可以通过discard来放弃组队

命令操作:开启事务->组队->执行

先开启事务(multi):将key1,key2放入队列中然后依次执行(exec)

注意:exec执行之后,事务结束

命令操作:开启事务->组队->放弃组队

 2.2 事务的错误处理

事务的错误处理分为两种情况,一种是在组队过程中发生了错误,一种是在执行的过程发生错误

组队过程中出现错误,执行时所有的队列都会被取消

 

由以上测试可知:当组队过程出现错误时,队伍中所有的元素都执行失败

执行过程中出现错误:不会影响队伍中正常元素的执行

 当我们将一个不会执行成功的元素放入队伍中(组队是不会出错,但执行到这行命令时会出错)

3 如何解决事务冲突

        悲观锁:每次拿数据时都会认为别人会修改,所以在每次拿数据时都会上锁,这样别人想拿数据时都会block直到拿到锁。传统的关系型数据库里面就用到了很多了很多这样的锁机制,比如行锁,表锁等,读锁,写锁,都是在做操作前先上锁

        乐观锁:每次拿数据时都会认为别人不会修改,所以不会上锁,但是在更新的时候会哦判断一下在此期间有没有别人去更新这个数据,可以使用版本号等机制。乐观锁适用于多读的应用类型,这样可以提高吞吐率。redis就是利用这种check-and-set机制实现事务的。

在redis中,可以通过WATCH key

在执行multi之前,先执行watch key1[key2] 可以监视一个(或多个)key,如果在事务执行之前这个(或这些key)被其他的命令所改动,那么事务将被打断。

4 Redis事务的三特性

单独的隔离操作:

        事务中百度所有命令都会序列化、按顺序的执行。事务在执行的过程中,不会被其他客户端发送来的命令请求所打断

没有隔离级别的概念:

        队列中的命令没有提交之前都不会实际被执行,因为事务提交之前任何指令都不会被        实际执行

不保证原子性:

        事务中如果有一条命令执行失败,其后的命令依然会被执行,没有回滚

标签:事务,命令,队列,Redis,组队,执行
来源: https://blog.csdn.net/qq_50652600/article/details/122770394

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有